الدالة ‎‎takeIf()‎ في Kotlin

من موسوعة حسوب

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

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

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

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

المعاملات

predicate

دالةٌ تطبق على كل كائن من الكائنات المعطاة وتعيد قيمة منطقية مقابلة لكلٍّ منها.

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

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

أمثلة

تستدعي الشيفرة الآتية الدالة takeIf()‎ عبر الكائن person المُنشَأ من الصنف Person الذي يحتوي على بيانات أوليّة لكلٍ من خاصيتيّ الاسم (name) والعمر (age) بهدف اختباره، فإن كانت الخاصية name مساويةً للقيمة "yaser" فستعيد الدالة الكائن 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 بخلاف ذلك.

مصادر