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

من موسوعة حسوب
مراجعة 18:51، 9 مايو 2018 بواسطة محمد-بغات (نقاش | مساهمات) (أنشأ الصفحة ب'<noinclude>{{DISPLAYTITLE: الدالة takeIf()‎ في لغة Kotlin}}</noinclude> تعيد الدالة takeIf()‎ الكائن الذي استُدعيت عبره إ...')
(فرق) → مراجعة أقدم | المراجعة الحالية (فرق) | مراجعة أحدث ← (فرق)

تعيد الدالة 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 خلاف ذلك.

مصادر

  • الدالة takeIf()‎ في التوثيق الرسميّ للمكتبة القياسيّة في لغة Kotlin.