الفرق بين المراجعتين ل"Kotlin/kotlin.text/getOrElse"

من موسوعة حسوب
اذهب إلى التنقل اذهب إلى البحث
(أنشأ الصفحة ب'<noinclude>{{DISPLAYTITLE: الدالة <code>text.getOrElse()‎</code> في لغة Kotlin}}</noinclude> تُراكِم الدالة<code>getOrElse()‎</code> الق...')
 
سطر 1: سطر 1:
 
<noinclude>{{DISPLAYTITLE: الدالة <code>text.getOrElse()‎</code> في لغة Kotlin}}</noinclude>
 
<noinclude>{{DISPLAYTITLE: الدالة <code>text.getOrElse()‎</code> في لغة Kotlin}}</noinclude>
تُراكِم الدالة<code>getOrElse()‎</code> القيم بدءًا من القيمة المُمرّرة <code>initial</code> وتطبّق العملية <code>operation</code> من اليمين إلى اليسار على القيمة الراهنة وعلى الحرف الموالي في  [[Kotlin/CharSequence/index|سلسلة الحروف]] التي استُدعيت عبرها. ثم تُعيد القيمة النهائية.   
+
تُعيد الدالة<code>getOrElse()‎</code> الحرف الموجود عند الفهرس المُمرّر  <code>index</code> في  [[Kotlin/CharSequence/index|سلسلة الحروف]] التي استُدعيت عبرها، أو ناتج استدعاء الدالة المُمررة  <code>defaultValue</code> على ذلك الفهرس إن كان خارج الحدود.   
 
==البنية العامة==
 
==البنية العامة==
 
<syntaxhighlight lang="kotlin">
 
<syntaxhighlight lang="kotlin">
inline fun <R> CharSequence.foldRight(
+
inline fun CharSequence.getOrElse(
     initial: R,  
+
     index: Int,  
     operation: (Char, acc: R) -> R
+
     defaultValue: (Int) -> Char
): R
+
): Char
 
</syntaxhighlight>يُلاحَظ وجود الكلمة المفتاحية <code>inline</code> للدلالة على أن هذه الدالة مباشرة، وللمزيد من التفاصيل راجع <nowiki/>[[Kotlin/inline functions|توثيق الدوال المباشرة (inline functions)]].
 
</syntaxhighlight>يُلاحَظ وجود الكلمة المفتاحية <code>inline</code> للدلالة على أن هذه الدالة مباشرة، وللمزيد من التفاصيل راجع <nowiki/>[[Kotlin/inline functions|توثيق الدوال المباشرة (inline functions)]].
  
 
==القيم المعادة==
 
==القيم المعادة==
القيمة النهائية لتطبيق العملية <code>operation</code>بشكل تراكمي على عناصر [[Kotlin/CharSequence/index|سلسلة الحروف]].
+
[[Kotlin/Char/index|حرف]].
  
 
==أمثلة==
 
==أمثلة==
 
===استخدام الدالة <code>()getOrElse</code> مع سلسلة نصية===
 
===استخدام الدالة <code>()getOrElse</code> مع سلسلة نصية===
تعرِّف الشيفرة الآتية  [[Kotlin/String|سلسلة نصية]] باسم <code>str</code>، ثمَّ تستدعي الدالة  <code>()getOrElse</code> عبرها مع تمرير القيمة الابتدائية <code>'A'</code> ودالة كوسيطين وتحيل القيمة الناتجة إلى المتغير <code>max</code>، <nowiki/>ثمَّ تطبع الناتج:<syntaxhighlight lang="kotlin">
+
تعرِّف الشيفرة الآتية  [[Kotlin/String|سلسلة نصية]] باسم <code>str</code>، ثمَّ تستدعي الدالة  <code>()getOrElse</code> عبرها مع تمرير عدد ودالة كوسيطين، <nowiki/>ثمَّ تطبع الناتج:<syntaxhighlight lang="kotlin">
 
fun main(args: Array<String>) {
 
fun main(args: Array<String>) {
val str = "hsoub wiki"
+
val str = "Hsoub"
   
+
 
val max = str.foldRight('A') { max, element -> if (max > element) max else element }
+
print(str.getOrElse(3) {it.toChar()}) // => u
print(max) // w
+
print(str.getOrElse(100) {it.toChar()}) // => d
 
}
 
}
 
</syntaxhighlight>
 
</syntaxhighlight>
سطر 30: سطر 30:
  
 
==مصادر==
 
==مصادر==
*[http://kotlinlang.org/api/latest/jvm/stdlib/kotlin.text/fold-right.html الدالة text.getOrElse()‎ في التوثيق الرسميّ للمكتبة القياسيّة في لغة Kotlin.]
+
*[http://kotlinlang.org/api/latest/jvm/stdlib/kotlin.text/get-or-else.html الدالة text.getOrElse()‎ في التوثيق الرسميّ للمكتبة القياسيّة في لغة Kotlin.]
 
[[تصنيف:Kotlin]]
 
[[تصنيف:Kotlin]]
 
[[تصنيف:Kotlin Functions]]
 
[[تصنيف:Kotlin Functions]]

مراجعة 17:04، 9 يوليو 2018

تُعيد الدالةgetOrElse()‎ الحرف الموجود عند الفهرس المُمرّر index في  سلسلة الحروف التي استُدعيت عبرها، أو ناتج استدعاء الدالة المُمررة  defaultValue على ذلك الفهرس إن كان خارج الحدود.

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

inline fun CharSequence.getOrElse(
    index: Int, 
    defaultValue: (Int) -> Char
): Char

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

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

حرف.

أمثلة

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

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

fun main(args: Array<String>) {
val str = "Hsoub"

print(str.getOrElse(3) {it.toChar()}) // => u
print(str.getOrElse(100) {it.toChar()}) // => d
}

انظر أيضًا

  • foldIndexed(): تُراكِم الدالةfoldIndexed()‎ القيم بدءًا من القيمة المُمرّرة initial وتطبّق العملية operation من اليسار إلى اليمين على القيمة الراهنة وعلى الحرف الموالي في  سلسلة الحروف التي استُدعيت عبرها وكذلك فهرسه. ثم تُعيد القيمة النهائية. 
  • fold(): تُراكِم الدالةfold()‎ القيم بدءًا من القيمة المُمرّرة initial وتطبّق العملية operation من اليسار إلى اليمين على القيمة الراهنة وعلى الحرف الموالي في  سلسلة الحروف التي استُدعيت عبرها. ثم تُعيد القيمة النهائية. 
  • elementAt(): تعيد الحرف الموجود في الفهرس المُحدّد في سلسلة الحروف التي استُدعيت عبرها، في حال كان الفهرس خارج الحدود فستطلق الاستثناء IndexOutOfBoundsException

مصادر