الفرق بين المراجعتين لصفحة: «Kotlin/takeIf»
< Kotlin
لا ملخص تعديل |
مراجعة |
||
سطر 1: | سطر 1: | ||
<noinclude>{{DISPLAYTITLE: الدالة takeIf() في لغة Kotlin}}</noinclude> | <noinclude>{{DISPLAYTITLE: الدالة takeIf() في لغة Kotlin}}</noinclude> | ||
تعيد الدالة <code>takeIf()</code> الكائن الذي استُدعيت عبره إن كان ذلك الكائن يحقق شرطًا معيّنًا، أو تعيد القيمة <code>null</code> | تعيد الدالة <code>takeIf()</code> الكائن (object) الذي استُدعيت عبره إن كان ذلك الكائن يحقق شرطًا معيّنًا، أو تعيد القيمة <code>null</code> بخلاف ذلك. | ||
== البنية العامة == | == البنية العامة == | ||
سطر 8: | سطر 8: | ||
== القيم المعادة == | == القيم المعادة == | ||
الكائن الذي استُدعيت الدالة عبره إن كان ذلك الكائن يحقق شرطًا معيّنًا، أو تُعيد القيمة <code>null</code> | الكائن الذي استُدعيت الدالة عبره إن كان ذلك الكائن يحقق شرطًا معيّنًا، أو تُعيد القيمة <code>null</code> بخلاف ذلك. | ||
== أمثلة == | == أمثلة == | ||
=== استخدام الدالة <code>takeIf()</code> مع الكائنات === | === استخدام الدالة <code>takeIf()</code> مع الكائنات === | ||
تستدعي الشيفرة الآتية الدالة <code>takeIf()</code> عبر الكائن <code>person</code> المُنشَأ من الصنف <code>Person</code> الذي يحتوي على بيانات أوليّة لكلٍ من خاصيتيّ الاسم (<code>name</code>) والعمر (<code>age</code>) بهدف اختباره، فإن كانت الخاصية <code>name</code> | تستدعي الشيفرة الآتية الدالة <code>takeIf()</code> عبر الكائن <code>person</code> المُنشَأ من الصنف <code>Person</code> الذي يحتوي على بيانات أوليّة لكلٍ من خاصيتيّ الاسم (<code>name</code>) والعمر (<code>age</code>) بهدف اختباره، فإن كانت الخاصية <code>name</code> مساويةً للقيمة <code>"yaser"</code> فستعيد الدالة الكائن <code>person</code> نفسه، وإلا فستعيد القيمة <code>null</code>:<syntaxhighlight lang="kotlin"> | ||
class Person { | class Person { | ||
var name = "yaser" | var name = "yaser" | ||
سطر 34: | سطر 34: | ||
== انظر أيضًا == | == انظر أيضًا == | ||
* | * الدالة [[kotlin/takeUnless|<code>()takeUnless</code>]]: تُعيد الكائن الذي استُدعيت عبره إن '''لم''' يحقق ذلك الكائن شرطًا معيّنًا، أو تعيد القيمة null بخلاف ذلك. | ||
== مصادر == | == مصادر == | ||
* [https://kotlinlang.org/api/latest/jvm/stdlib/kotlin/take-if.html الدالة takeIf() في التوثيق الرسميّ للمكتبة القياسيّة في لغة Kotlin.] | * [https://kotlinlang.org/api/latest/jvm/stdlib/kotlin/take-if.html صفحة الدالة takeIf() في التوثيق الرسميّ للمكتبة القياسيّة في لغة Kotlin.] | ||
[[تصنيف:Kotlin]] | [[تصنيف:Kotlin]] | ||
[[تصنيف:Kotlin | [[تصنيف:Kotlin Function]] |
مراجعة 14:33، 26 مايو 2018
تعيد الدالة takeIf()
الكائن (object) الذي استُدعيت عبره إن كان ذلك الكائن يحقق شرطًا معيّنًا، أو تعيد القيمة null
بخلاف ذلك.
البنية العامة
inline fun <T> T.takeIf(predicate: (T) -> Boolean): T?
يُلاحَظ وجود الكلمة المفتاحية inline
للدلالة على أن هذه الدالة مباشرة، وللمزيد من التفاصيل راجع توثيق الدوال المباشرة (inline functions).
القيم المعادة
الكائن الذي استُدعيت الدالة عبره إن كان ذلك الكائن يحقق شرطًا معيّنًا، أو تُعيد القيمة null
بخلاف ذلك.
أمثلة
استخدام الدالة takeIf()
مع الكائنات
تستدعي الشيفرة الآتية الدالة 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 بخلاف ذلك.