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

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


في حال تمرير شرط منطقي <code>predicate</code> كوسيط فستعيد الدالة <code>single()‎</code>الحرف الوحيد الذي يحقق ذلك الشرط. وفي حال لم يكن هناك أي حرف يحقق ذلك الشرط أو كان هناك أكثر من حرف واحد يحققه فستطلق استثناء.   
في حال تمرير شرط منطقي <code>predicate</code> كوسيط فستعيد الدالة <code>single()‎</code>الحرف الوحيد الذي يحقق ذلك الشرط. وفي حال لم يكن هناك أي حرف يحقق ذلك الشرط أو كان هناك أكثر من حرف واحد يحققه فستعيد <code>null</code>.   
==البنية العامة==
==البنية العامة==
<syntaxhighlight lang="kotlin">
<syntaxhighlight lang="kotlin">
fun CharSequence.single(): Char  
fun CharSequence.singleOrNull(): Char?
 
inline fun CharSequence.singleOrNull(
inline fun CharSequence.single(
     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)]].


سطر 21: سطر 20:
val str = "H"  
val str = "H"  
      
      
println( str.single () ) // H
println( str.singleOrNull () ) // H
}
}
</syntaxhighlight>
</syntaxhighlight>
سطر 29: سطر 28:
val str = "Hsoub"  
val str = "Hsoub"  
      
      
println( str.single {it.isUpperCase()} ) // H
println( str.single {it.singleOrNull()} ) // H
}
}
</syntaxhighlight>
</syntaxhighlight>
سطر 37: سطر 36:
val str = "hsoub"  
val str = "hsoub"  
      
      
println( str.single {it.isUpperCase()} ) // إطلاق استثناء
println( str.single {it.singleOrNull()} ) // null
}
}
</syntaxhighlight>
</syntaxhighlight>


== انظر أيضًا ==
== انظر أيضًا ==
* <code>[[Kotlin/kotlin.text/elementAtOrElse|elementAtOrElse()]]‎</code>:تعيد الحرف الموجود في الفهرس المُحدّد في [[Kotlin/CharSequence/index|سلسلة الحروف]] التي استُدعيت عبرها، وفي حال كان الفهرس خارج الحدود فستعيد ناتج تمرير ذلك الفهرس إلى الدالة المُمررة <code>defaultValue.</code>
* <code>[[Kotlin/kotlin.text/single|single()]]‎</code>: تتعيد الدالة <code>single()‎</code> الحرف الوحيد في [[Kotlin/CharSequence/index|سلسلة الحروف]] التي استُدعيت عبرها، وفي حال كانت [[Kotlin/CharSequence/index|سلسلة الحروف]] فارغة أو تحتوي أكثر من حرف واحد فستطلق استثناء. 
 
* <code>[[Kotlin/kotlin.text/elementAtOrElse|elementAtOrElse()]]‎</code>: تعيد الحرف الموجود في الفهرس المُحدّد في [[Kotlin/CharSequence/index|سلسلة الحروف]] التي استُدعيت عبرها، وفي حال كان الفهرس خارج الحدود فستعيد ناتج تمرير ذلك الفهرس إلى الدالة المُمررة <code>defaultValue.</code>


* <code>[[Kotlin/kotlin.text/drop|drop()]]‎</code>: تعيد جزءًا من السلسلة النصية أو سلسلة الحروف التي استُدعيت عبرها مع حذف أول <code>n</code> حرفًا. 
* <code>[[Kotlin/kotlin.text/drop|drop()]]‎</code>: تعيد جزءًا من السلسلة النصية أو سلسلة الحروف التي استُدعيت عبرها مع حذف أول <code>n</code> حرفًا. 
* <code>[[Kotlin/kotlin.text/asSequence|asSequence()]]‎</code>: تنشئ كائنًا من الصنف <code>Sequence</code> والذي يُغلّف سلسلة الحروف التي استُدعيت عبرها، لأجل استعمالها في الحلقات التكرارية.


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

مراجعة 11:04، 12 يوليو 2018

تعيد الدالة singleOrNull()‎ الحرف الوحيد في سلسلة الحروف التي استُدعيت عبرها، وفي حال كانت سلسلة الحروف فارغة أو تحتوي أكثر من حرف واحد فستعيد null.

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

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

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

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

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

حرف.

أمثلة

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

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

fun main(args: Array<String>) {
val str = "H" 
    
println( str.singleOrNull () ) // H
}

استخدام الدالة ()singleOrNull مع سلسلة نصية مع تمرير دالة كوسيط

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

fun main(args: Array<String>) {
val str = "Hsoub" 
    
println( str.single {it.singleOrNull()} ) // H
}

استخدام الدالة ()singleOrNull مع سلسلة نصية مع تمرير دالة كوسيط: الحالة الثانية

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

fun main(args: Array<String>) {
val str = "hsoub" 
    
println( str.single {it.singleOrNull()} ) // null
}

انظر أيضًا

  • single(): تتعيد الدالة single()‎ الحرف الوحيد في سلسلة الحروف التي استُدعيت عبرها، وفي حال كانت سلسلة الحروف فارغة أو تحتوي أكثر من حرف واحد فستطلق استثناء. 
  • elementAtOrElse(): تعيد الحرف الموجود في الفهرس المُحدّد في سلسلة الحروف التي استُدعيت عبرها، وفي حال كان الفهرس خارج الحدود فستعيد ناتج تمرير ذلك الفهرس إلى الدالة المُمررة defaultValue.
  • drop(): تعيد جزءًا من السلسلة النصية أو سلسلة الحروف التي استُدعيت عبرها مع حذف أول n حرفًا. 

مصادر