الفرق بين المراجعتين لصفحة: «Kotlin/kotlin.text/single»
ط استبدال النص - 'Kotlin Functions' ب'Kotlin Function' |
جميل-بيلوني (نقاش | مساهمات) مراجعة وتدقيق. |
||
سطر 1: | سطر 1: | ||
<noinclude>{{DISPLAYTITLE: الدالة <code> | <noinclude>{{DISPLAYTITLE: الدالة <code>CharSequence.single()</code> في Kotlin}}</noinclude> | ||
تتحقَّق الدالة <code>single()</code> من حواية سلسلة المحارف التي استُدعيت معها محرفًا واحدًا فقط أو محرفًا واحدًا محققًا لشرط معيَّن ثمَّ تعيده أو تطلق استثناءً خلاف ذلك. | |||
== البنية العامة == | |||
==البنية العامة== | |||
<syntaxhighlight lang="kotlin"> | <syntaxhighlight lang="kotlin"> | ||
fun CharSequence.single(): | fun CharSequence.single(): Char | ||
inline fun CharSequence.single( | inline fun CharSequence.single( | ||
predicate: (Char) -> Boolean | |||
): Char | ): Char | ||
</syntaxhighlight> | </syntaxhighlight>وجود الكلمة المفتاحية <code>inline</code> يدل على أن هذه الدالة مباشرة (للمزيد من التفاصيل، راجع صفحة [[Kotlin/inline functions|الدوال المباشرة]] (inline functions)). | ||
== | == المعاملات == | ||
=== <code>predicate</code> === | |||
=== | دالة تطبق على كل محرف من محارف السلسلة المعطاة. يمرر إليها محرفٌ وتعيد قيمة منطقية مقابله له. | ||
== القيم المعادة == | |||
يعاد المحرف الوحيد الموجود في سلسلة المحارف المعطاة، أو المحرف الوحيد الذي حقق الشرط <code>predicate</code> (إن أعطي)، أو يُطلق استثناءٌ خلاف ذلك. | |||
== أمثلة == | |||
مثالٌ على استعمال الدالة <code>()single</code>:<syntaxhighlight lang="kotlin"> | |||
fun main(args: Array<String>) { | fun main(args: Array<String>) { | ||
println("w".single()) // w | |||
println("wikiHsoub".single { it.isUpperCase() }) // H | |||
println( | |||
} | } | ||
</syntaxhighlight> | |||
</syntaxhighlight>مثالٌ آخر على استعمال الدالة <code>()single</code> عندما يكون هنالك أكثر من محرف محقق لشرط معين:<syntaxhighlight lang="kotlin"> | |||
fun main(args: Array<String>) { | fun main(args: Array<String>) { | ||
println("HSoub".single { it.isUpperCase() }) | |||
println( | |||
} | } | ||
</syntaxhighlight>يعطي هذا المثال عند تنفيذه الناتج التالي:<syntaxhighlight lang="text"> | |||
Exception in thread "main" java.lang.IllegalArgumentException: Char sequence contains more than one matching element. | |||
at TestKt.main(test.kt:9) | |||
</syntaxhighlight> | </syntaxhighlight> | ||
== انظر أيضًا == | == انظر أيضًا == | ||
elementAtOrElse():تعيد الحرف الموجود في الفهرس المُحدّد في سلسلة الحروف التي استُدعيت عبرها، وفي حال كان الفهرس خارج الحدود فستعيد ناتج تمرير ذلك الفهرس إلى الدالة المُمررة defaultValue. | |||
drop(): تعيد جزءًا من السلسلة النصية أو سلسلة الحروف التي استُدعيت عبرها مع حذف أول n حرفًا. | |||
singleOrNull(): تعيد الدالة singleOrNull() الحرف الوحيد في سلسلة الحروف التي استُدعيت عبرها، وفي حال كانت سلسلة الحروف فارغة أو تحتوي أكثر من حرف واحد فستعيد null. | |||
* | == مصادر == | ||
* [http://kotlinlang.org/api/latest/jvm/stdlib/kotlin.text/single.html صفحة الدالة CharSequence.single() في التوثيق الرسميّ للمكتبة القياسيّة في لغة Kotlin.] | |||
[[تصنيف:Kotlin]] | [[تصنيف:Kotlin]] | ||
[[تصنيف:Kotlin Function]] | [[تصنيف:Kotlin Function]] | ||
[[تصنيف:Kotlin Text]] | |||
[[تصنيف:Kotlin CharSequence]] |
مراجعة 11:56، 5 سبتمبر 2018
تتحقَّق الدالة single()
من حواية سلسلة المحارف التي استُدعيت معها محرفًا واحدًا فقط أو محرفًا واحدًا محققًا لشرط معيَّن ثمَّ تعيده أو تطلق استثناءً خلاف ذلك.
البنية العامة
fun CharSequence.single(): Char
inline fun CharSequence.single(
predicate: (Char) -> Boolean
): Char
وجود الكلمة المفتاحية inline
يدل على أن هذه الدالة مباشرة (للمزيد من التفاصيل، راجع صفحة الدوال المباشرة (inline functions)).
المعاملات
predicate
دالة تطبق على كل محرف من محارف السلسلة المعطاة. يمرر إليها محرفٌ وتعيد قيمة منطقية مقابله له.
القيم المعادة
يعاد المحرف الوحيد الموجود في سلسلة المحارف المعطاة، أو المحرف الوحيد الذي حقق الشرط predicate
(إن أعطي)، أو يُطلق استثناءٌ خلاف ذلك.
أمثلة
مثالٌ على استعمال الدالة ()single
:
fun main(args: Array<String>) {
println("w".single()) // w
println("wikiHsoub".single { it.isUpperCase() }) // H
}
مثالٌ آخر على استعمال الدالة ()single
عندما يكون هنالك أكثر من محرف محقق لشرط معين:
fun main(args: Array<String>) {
println("HSoub".single { it.isUpperCase() })
}
يعطي هذا المثال عند تنفيذه الناتج التالي:
Exception in thread "main" java.lang.IllegalArgumentException: Char sequence contains more than one matching element.
at TestKt.main(test.kt:9)
انظر أيضًا
elementAtOrElse():تعيد الحرف الموجود في الفهرس المُحدّد في سلسلة الحروف التي استُدعيت عبرها، وفي حال كان الفهرس خارج الحدود فستعيد ناتج تمرير ذلك الفهرس إلى الدالة المُمررة defaultValue.
drop(): تعيد جزءًا من السلسلة النصية أو سلسلة الحروف التي استُدعيت عبرها مع حذف أول n حرفًا.
singleOrNull(): تعيد الدالة singleOrNull() الحرف الوحيد في سلسلة الحروف التي استُدعيت عبرها، وفي حال كانت سلسلة الحروف فارغة أو تحتوي أكثر من حرف واحد فستعيد null.