الفرق بين المراجعتين ل"Kotlin/takeIf"

من موسوعة حسوب
اذهب إلى التنقل اذهب إلى البحث
(أنشأ الصفحة ب'<noinclude>{{DISPLAYTITLE: الدالة takeIf()‎ في لغة Kotlin}}</noinclude> تعيد الدالة takeIf()‎ الكائن الذي استُدعيت عبره إ...')
 
سطر 1: سطر 1:
 
<noinclude>{{DISPLAYTITLE: الدالة takeIf()‎ في لغة Kotlin}}</noinclude>
 
<noinclude>{{DISPLAYTITLE: الدالة takeIf()‎ في لغة Kotlin}}</noinclude>
تعيد الدالة takeIf()‎ الكائن الذي استُدعيت عبره إن كان ذلك الكائن يحقق شرطًا معيّنًا، أو تعيد القيمة null خلاف ذلك.
+
تعيد الدالة <code>takeIf()‎</code> الكائن الذي استُدعيت عبره إن كان ذلك الكائن يحقق شرطًا معيّنًا، أو تعيد القيمة <code>null</code> خلاف ذلك.
  
 
== البنية العامة ==
 
== البنية العامة ==
 +
<syntaxhighlight lang="kotlin">
 
inline fun <T> T.takeIf(predicate: (T) -> Boolean): T?
 
inline fun <T> T.takeIf(predicate: (T) -> Boolean): T?
 
+
</syntaxhighlight>يُلاحَظ وجود الكلمة المفتاحية <code>inline</code> للدلالة على أن هذه الدالة مباشرة، وللمزيد من التفاصيل راجع [[Kotlin/inline functions|توثيق الدوال المباشرة (inline functions)]].
يُلاحَظ وجود الكلمة المفتاحية inline للدلالة على أن هذه الدالة مباشرة، وللمزيد من التفاصيل راجع [[Kotlin/inline functions|توثيق الدوال المباشرة (inline functions)]].
 
  
 
== القيم المعادة ==
 
== القيم المعادة ==
الكائن الذي استُدعيت الدالة عبره إن كان ذلك الكائن يحقق شرطًا معيّنًا، أو تُعيد القيمة null خلاف ذلك.
+
الكائن الذي استُدعيت الدالة عبره إن كان ذلك الكائن يحقق شرطًا معيّنًا، أو تُعيد القيمة <code>null</code> خلاف ذلك.
  
 
== أمثلة ==
 
== أمثلة ==
  
=== استخدام الدالة takeIf()‎ مع الكائنات ===
+
=== استخدام الدالة <code>takeIf()‎</code> مع الكائنات ===
تستدعي الشيفرة الآتية الدالة takeIf()‎ عبر الكائن person المُنشَأ من الصنف Person الذي يحتوي على بيانات أوليّة لكلٍ من خاصيتيّ الاسم (name) والعمر (age) بهدف اختباره، فإن كانت الخاصية name مساوية للقيمة "bob" فستعيد الدالة الكائن person نفسه وإلا فستعيد القيمة null:
+
تستدعي الشيفرة الآتية الدالة <code>takeIf()‎</code> عبر الكائن <code>person</code> المُنشَأ من الصنف <code>Person</code> الذي يحتوي على بيانات أوليّة لكلٍ من خاصيتيّ الاسم (<code>name</code>) والعمر (<code>age</code>) بهدف اختباره، فإن كانت الخاصية <code>name</code> مساوية للقيمة <code>"bob"</code> فستعيد الدالة الكائن <code>person</code> نفسه وإلا فستعيد القيمة <code>null</code>:<syntaxhighlight lang="kotlin">
 
 
 
class Person {
 
class Person {
 
 
   var name = "yaser"
 
   var name = "yaser"
 
 
   var age = 52
 
   var age = 52
 
 
}
 
}
  
 
fun main(args: Array<String>) {
 
fun main(args: Array<String>) {
 
 
   // الحالة الأولى
 
   // الحالة الأولى
 
 
   val person = Person()
 
   val person = Person()
 
 
   val x= person.takeIf {person.name == "yaser"}
 
   val x= person.takeIf {person.name == "yaser"}
 
 
   println(x?.name)   // yaser   
 
   println(x?.name)   // yaser   
  
 
   // الحالة الثانية
 
   // الحالة الثانية
 
 
   val person2 = Person()
 
   val person2 = Person()
 
 
   person2.name= "karim"
 
   person2.name= "karim"
 
 
   val y= person2.takeIf {person2.name == "yaser"}  
 
   val y= person2.takeIf {person2.name == "yaser"}  
 
 
   println(y)   // null
 
   println(y)   // null
 
 
}
 
}
 +
</syntaxhighlight>
  
 
== انظر أيضًا ==
 
== انظر أيضًا ==
* ()takeUnless: تُعيد الكائن الذي استُدعيت عبره إن لم يحقق ذلك الكائن شرطًا معيّنًا، أو تعيد القيمة null خلاف ذلك.
+
* <code>[[kotlin/takeUnless|()takeUnless]]</code>: تُعيد الكائن الذي استُدعيت عبره إن لم يحقق ذلك الكائن شرطًا معيّنًا، أو تعيد القيمة null خلاف ذلك.
  
 
== مصادر ==
 
== مصادر ==
* الدالة takeIf()‎ في التوثيق الرسميّ للمكتبة القياسيّة في لغة Kotlin.
+
* [https://kotlinlang.org/api/latest/jvm/stdlib/kotlin/take-if.html الدالة takeIf()‎ في التوثيق الرسميّ للمكتبة القياسيّة في لغة Kotlin.]
 
[[تصنيف:Kotlin]]
 
[[تصنيف:Kotlin]]
 
[[تصنيف:Kotlin Functions]]
 
[[تصنيف:Kotlin Functions]]

مراجعة 18:55، 9 مايو 2018

تعيد الدالة takeIf()‎ الكائن الذي استُدعيت عبره إن كان ذلك الكائن يحقق شرطًا معيّنًا، أو تعيد القيمة null خلاف ذلك.

البنية العامة

inline fun <T> T.takeIf(predicate: (T) -> Boolean): T?

يُلاحَظ وجود الكلمة المفتاحية inline للدلالة على أن هذه الدالة مباشرة، وللمزيد من التفاصيل راجع توثيق الدوال المباشرة (inline functions).

القيم المعادة

الكائن الذي استُدعيت الدالة عبره إن كان ذلك الكائن يحقق شرطًا معيّنًا، أو تُعيد القيمة null خلاف ذلك.

أمثلة

استخدام الدالة takeIf()‎ مع الكائنات

تستدعي الشيفرة الآتية الدالة takeIf()‎ عبر الكائن person المُنشَأ من الصنف Person الذي يحتوي على بيانات أوليّة لكلٍ من خاصيتيّ الاسم (name) والعمر (age) بهدف اختباره، فإن كانت الخاصية name مساوية للقيمة "bob" فستعيد الدالة الكائن person نفسه وإلا فستعيد القيمة null:

class Person {
   var name = "yaser"
   var age = 52
}

fun main(args: Array<String>) {
   // الحالة الأولى
   val person = Person()
   val x= person.takeIf {person.name == "yaser"}
   println(x?.name)   // yaser   

   // الحالة الثانية
   val person2 = Person()
   person2.name= "karim"
   val y= person2.takeIf {person2.name == "yaser"}  
   println(y)   // null
}

انظر أيضًا

  • ()takeUnless: تُعيد الكائن الذي استُدعيت عبره إن لم يحقق ذلك الكائن شرطًا معيّنًا، أو تعيد القيمة null خلاف ذلك.

مصادر