الدالة text.singleOrNull()
في لغة Kotlin
تعيد الدالة 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
حرفًا.