الفرق بين المراجعتين لصفحة: «Kotlin/kotlin.text/firstOrNull»

من موسوعة حسوب
أنشأ الصفحة ب'<noinclude>{{DISPLAYTITLE: الدالة <code>text.firstOrNull()‎</code> في لغة Kotlin}}</noinclude> تعيد الدالة <code>firstOrNull()</code>‎ Kotlin/...'
 
لا ملخص تعديل
سطر 2: سطر 2:
تعيد الدالة <code>firstOrNull()</code>‎ [[Kotlin/Char/index|الحرف]] الأول من [[Kotlin/CharSequence/index|سلسلة الحروف]] التي استُدعيت عبرها، وفي حال تمرير دالة منطقية <code>predicate</code> كوسيط فستعيد  [[Kotlin/Char/index|الحرف]] الأول الذي يحقق الشرط المنطقي <code>predicate</code>.   
تعيد الدالة <code>firstOrNull()</code>‎ [[Kotlin/Char/index|الحرف]] الأول من [[Kotlin/CharSequence/index|سلسلة الحروف]] التي استُدعيت عبرها، وفي حال تمرير دالة منطقية <code>predicate</code> كوسيط فستعيد  [[Kotlin/Char/index|الحرف]] الأول الذي يحقق الشرط المنطقي <code>predicate</code>.   


تطلق   الدالة <code>first()</code>‎  استثناء <code>NoSuchElementException</code> إن كانت  [[Kotlin/CharSequence/index|سلسلة الحروف]] فارغة.   
تعيد الدالة <code>first()</code>‎  القيمة <code>null</code> إن كانت  [[Kotlin/CharSequence/index|سلسلة الحروف]] فارغة أو لم يكن هناك أي حرف  يحقق  الشرط المنطقي <code>predicate</code>.   
==البنية العامة==
==البنية العامة==
<syntaxhighlight lang="kotlin">
<syntaxhighlight lang="kotlin">
fun CharSequence.first(): Char  
fun CharSequence.firstOrNull(): Char?


inline fun CharSequence.first(
inline fun CharSequence.firstOrNull(
     predicate: (Char) -> Boolean
     predicate: (Char) -> Boolean
): Char
): Char?
 
</syntaxhighlight>يُلاحَظ وجود الكلمة المفتاحية <code>inline</code> للدلالة على أن هذه الدالة مباشرة، وللمزيد من التفاصيل راجع <nowiki/>[[Kotlin/inline functions|توثيق الدوال المباشرة (inline functions)]].
</syntaxhighlight>يُلاحَظ وجود الكلمة المفتاحية <code>inline</code> للدلالة على أن هذه الدالة مباشرة، وللمزيد من التفاصيل راجع <nowiki/>[[Kotlin/inline functions|توثيق الدوال المباشرة (inline functions)]].


==القيم المعادة==
==القيم المعادة==
[[Kotlin/Char/index|حرف]].
[[Kotlin/Char/index|حرف]] أو <code>null</code>.


==أمثلة==
==أمثلة==
===استخدام الدالة <code>()firstOrNull</code> مع سلسلة نصية===
===استخدام الدالة <code>()firstOrNull</code> مع سلسلة نصية===
تعرِّف الشيفرة الآتية  [[Kotlin/String|سلسلة نصية]] باسم <code>str</code>، ثمَّ تستدعي الدالة  <code>()firstOrNull</code> عبرها مع تمرير دالة منطقية كوسيط، <nowiki/>ثمَّ تطبع الناتج:<syntaxhighlight lang="kotlin">
تعرِّف الشيفرة الآتية  [[Kotlin/String|سلسلة نصية]] باسم <code>str</code>، ثمَّ تستدعي الدالة  <code>()firstOrNull</code> عبرها مع تمرير دالة منطقية كوسيط، كما تستدعيها كذلك عبر [[Kotlin/String|سلسلة نصية]] فارغة، <nowiki/>ثمَّ تطبع الناتج:<syntaxhighlight lang="kotlin">
fun main(args: Array<String>) {
fun main(args: Array<String>) {
val str = "hsoub Wiki"  
val str = "hsoub Wiki"  
      
      
println(str.first {it.isUpperCase()} ) //  W
println(str.firstOrNull {it.isUpperCase()} ) //  W
println("".firstOrNull () ) //  null
}
}
</syntaxhighlight>
</syntaxhighlight>
==انظر أيضًا==
==انظر أيضًا==
* <code>[[Kotlin/kotlin.text/findAnyOf|findAnyOf()]]‎</code>:تبحث الدالة <code>findAnyOf()</code>‎ عن أول ظهور لأي واحدة من [[Kotlin/String|السلاسل النصية]] الموجودة في الوسيط المُمرّر <code>strings</code>  في [[Kotlin/CharSequence/index|سلسلة الحروف]] التي استُدعيت عبرها بداية من الفهرس <code>startIndex،</code> وفي حال إعطاء القيمة <code>true</code> للوسيط <code>ignoreCase</code> فستتجاهل الدالة حالة الحروف.
* <code>[[Kotlin/kotlin.text/first|first()]]‎</code>: تعيد [[Kotlin/Char/index|الحرف]] الأول من [[Kotlin/CharSequence/index|سلسلة الحروف]] التي استُدعيت عبرها، وفي حال تمرير دالة منطقية <code>predicate</code> كوسيط فستعيد  [[Kotlin/Char/index|الحرف]] الأول الذي يحقق الشرط المنطقي <code>predicate</code>. 
* <code>[[Kotlin/kotlin.text/find|find()]]‎</code>: تعيد أول حرف من سلسلة الحروف التي استُدعيت عبرها يحقق الشرط المنطقي <code>predicate.</code>
* <code>[[Kotlin/kotlin.text/find|find()]]‎</code>: تعيد أول حرف من سلسلة الحروف التي استُدعيت عبرها يحقق الشرط المنطقي <code>predicate.</code>


سطر 33: سطر 35:


==مصادر==
==مصادر==
*[http://kotlinlang.org/api/latest/jvm/stdlib/kotlin.text/first.html الدالة text.firstOrNull()‎ في التوثيق الرسميّ للمكتبة القياسيّة في لغة Kotlin.]
*[http://kotlinlang.org/api/latest/jvm/stdlib/kotlin.text/first-or-null.html الدالة text.firstOrNull()‎ في التوثيق الرسميّ للمكتبة القياسيّة في لغة Kotlin.]
[[تصنيف:Kotlin]]
[[تصنيف:Kotlin]]
[[تصنيف:Kotlin Functions]]
[[تصنيف:Kotlin Functions]]

مراجعة 22:46، 8 يوليو 2018

تعيد الدالة firstOrNull()الحرف الأول من سلسلة الحروف التي استُدعيت عبرها، وفي حال تمرير دالة منطقية predicate كوسيط فستعيد الحرف الأول الذي يحقق الشرط المنطقي predicate.

تعيد الدالة first()‎ القيمة null إن كانت سلسلة الحروف فارغة أو لم يكن هناك أي حرف يحقق الشرط المنطقي predicate.

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

fun CharSequence.firstOrNull(): Char? 

inline fun CharSequence.firstOrNull(
    predicate: (Char) -> Boolean
): Char?

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

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

حرف أو null.

أمثلة

استخدام الدالة ()firstOrNull مع سلسلة نصية

تعرِّف الشيفرة الآتية سلسلة نصية باسم str، ثمَّ تستدعي الدالة ()firstOrNull عبرها مع تمرير دالة منطقية كوسيط، كما تستدعيها كذلك عبر سلسلة نصية فارغة، ثمَّ تطبع الناتج:

fun main(args: Array<String>) {
val str = "hsoub Wiki" 
    
println(str.firstOrNull {it.isUpperCase()} ) //  W
println("".firstOrNull () ) //  null
}

انظر أيضًا

  • first(): تعيد الحرف الأول من سلسلة الحروف التي استُدعيت عبرها، وفي حال تمرير دالة منطقية predicate كوسيط فستعيد الحرف الأول الذي يحقق الشرط المنطقي predicate
  • find(): تعيد أول حرف من سلسلة الحروف التي استُدعيت عبرها يحقق الشرط المنطقي predicate.
  • filterIndexed(): تعيد الدالة filterIndexed()‎ كل الحروف من سلسلة الحروف التي استُدعيت عبرها والتي تحقق الشرط المنطقي. يمرَّر فهرس كل عنصر وقيمته إلى الدالة predicate()‎ ثم تعيد بدورها قيمة منطقيَّة. 
  • elementAt(): تعيد الحرف الموجود في الفهرس المُحدّد في سلسلة الحروف التي استُدعيت عبرها، في حال كان الفهرس خارج الحدود فستطلق الاستثناء IndexOutOfBoundsException

مصادر