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

من موسوعة حسوب
أنشأ الصفحة ب'<noinclude>{{DISPLAYTITLE: التابع text.zipWithNext()‎ في لغة Kotlin}}</noinclude> تعيد الدالة <code>zipWithNext()</code>‎ Kotlin/List|لائح...'
 
لا ملخص تعديل
سطر 1: سطر 1:
<noinclude>{{DISPLAYTITLE: التابع text.zipWithNext()‎ في لغة Kotlin}}</noinclude>
<noinclude>{{DISPLAYTITLE: التابع text.zipWithNext()‎ في لغة Kotlin}}</noinclude>
تعيد الدالة <code>zipWithNext()</code>‎ [[Kotlin/List|لائحة]] تحتوي كل حروف [[Kotlin/CharSequence/index|سلسلة الحروف]]  التي استٌدعيت عبرها.
يختلف سلوك الدالة <code>zipWithNext()</code>‎ بحسب نوع وعدد الوسائط المُمرّرة (انظر فقرة [[Kotlin/kotlin.text/zipWithNext#.D8.A7.D9.84.D8.A8.D9.86.D9.8A.D8.A9%20.D8.A7.D9.84.D8.B9.D8.A7.D9.85.D8.A9|البنية العامة]]).
==البنية العامة==
==البنية العامة==
<syntaxhighlight lang="kotlin">
<syntaxhighlight lang="kotlin">
infix fun CharSequence.zip(
fun CharSequence.zipWithNext(): List<Pair<Char, Char>>  
    other: CharSequence
 
): List<Pair<Char, Char>>  
</syntaxhighlight>'''بيئة التشغيل المطلوبة: Kotlin 1.2'''
</syntaxhighlight>تعيد الدالة <code>zipWithNext()</code>‎ [[Kotlin/List|لائحة]] تحتوي [[Kotlin/Pair/index|أزواجًا]] (pairs) مُركّبة من حروف [[Kotlin/CharSequence/index|سلسلة الحروف]]  التي استٌدعيت عبرها ومن حروف السلسلة الأخرى المًمرّرة <code>other</code> التي لها نفس الفهرس، [[Kotlin/List|اللائحة]] المُعادة لها طول أقصر [[Kotlin/CharSequence/index|سلسلة حروف]].<syntaxhighlight lang="kotlin">
 
inline fun <V> CharSequence.zip(
تعيد الدالة <code>zipWithNext()</code>‎ [[Kotlin/List|لائحة]] تحتوي [[Kotlin/Pair/index|أزواجًا]] (pairs) مُركّبة من حروف [[Kotlin/CharSequence/index|سلسلة الحروف]]  التي استٌدعيت عبرها ومن حروف السلسلة الأخرى المًمرّرة <code>other</code> التي عند الفهرس الموالي، [[Kotlin/List|اللائحة]] المُعادة ستكون فارغة إن  كانت [[Kotlin/CharSequence/index|سلسلة حروف]] الأصلية تحتوي أقل من حرفين.<syntaxhighlight lang="kotlin">
    other: CharSequence,
inline fun <R> CharSequence.zipWithNext(
     transform: (a: Char, b: Char) -> V
     transform: (a: Char, b: Char) -> R
): List<V>  
): List<R>  
</syntaxhighlight>تعيد الدالة <code>zipWithNext()</code>‎ [[Kotlin/List|لائحة]] تحتوي  نتائج تطبيق الدالة المُمرّرة <code>transform</code> على حروف [[Kotlin/CharSequence/index|سلسلة الحروف]]  التي استٌدعيت عبرها وعلى حروف السلسلة الأخرى المًمرّرة <code>other</code> التي لها نفس الفهرس، [[Kotlin/List|اللائحة]] المُعادة لها طول أقصر [[Kotlin/CharSequence/index|سلسلة حروف]].
</syntaxhighlight>'''بيئة التشغيل المطلوبة: Kotlin 1.2'''
 
تعيد الدالة <code>zipWithNext()</code>‎ [[Kotlin/List|لائحة]] تحتوي  نتائج تطبيق الدالة المُمرّرة <code>transform</code> على حروف [[Kotlin/CharSequence/index|سلسلة الحروف]]  التي استٌدعيت عبرها وعلى حروف السلسلة الأخرى المًمرّرة <code>other</code> التي عند الفهرس الموالي، [[Kotlin/List|اللائحة]] المُعادة ستكون فارغة إن  كانت [[Kotlin/CharSequence/index|سلسلة حروف]] الأصلية تحتوي أقل من حرفين.
 
يُلاحَظ وجود الكلمة المفتاحية <code>inline</code> للدلالة على أن هذه الدالة مباشرة، وللمزيد من التفاصيل راجع <nowiki/>[[Kotlin/inline functions|توثيق الدوال المباشرة (inline functions)]].


==القيم المعادة==
==القيم المعادة==
[[Kotlin/List|لائحة]].
[[Kotlin/List|لائحة]].
==أمثلة==
==أمثلة==
===استخدام الدالة <code>zipWithNext()‎</code> مع السلاسل النصية===
===استخدام الدالة <code>zipWithNext()‎</code> مع السلاسل النصية ===
تستدعي الشيفرة الآتية الدالة <code>zipWithNext()‎</code> عبر عدة [[Kotlin/String|سلاسل نصية]] مع تمرير [[Kotlin/String|سلسلة نصية]] كوسيط، وتطبع الناتج:<syntaxhighlight lang="kotlin">
تعرّف الشيفرة الآتية [[Kotlin/List|لائحة]] حروف باسم <code>letters،</code>  ثم تستدعي الدالة <code>zipWithNext()‎</code> عبرها وتحيل الناتج إلى المتغير <code>pairs</code>، وتطبع الناتج:<syntaxhighlight lang="kotlin">
fun main(args: Array<String>) {
fun main(args: Array<String>) {
println("hsoub".zip("12345")) // [(h, 1), (s, 2), (o, 3), (u, 4), (b, 5)]
val letters = ('a'..'f').toList()
println("hsoub".zip("12")) // [(h, 1), (s, 2)]
val pairs = letters.zipWithNext()
println("hsoub" zip "HSOUB") // [(h, H), (s, S), (o, O), (u, U), (b, B)]
 
println(letters) // [a, b, c, d, e, f]
println(pairs) // [(a, b), (b, c), (c, d), (d, e), (e, f)]
}
}
</syntaxhighlight>
</syntaxhighlight>
===ستخدام الدالة <code>zipWithNext()‎</code> مع السلاسل النصية مع تمرير دالة===
===استخدام الدالة <code>zipWithNext()‎</code> مع السلاسل النصية مع تمرير دالة===
تستدعي الشيفرة الآتية الدالة <code>zipWithNext()‎</code> عبر عدة [[Kotlin/String|سلاسل نصية]] مع تمرير [[Kotlin/String|سلسلة نصية]] ودالة كوسيط، وتطبع الناتج:<syntaxhighlight lang="kotlin">
تعرّف الشيفرة الآتية [[Kotlin/List|لائحة]] أعداد باسم <code>values</code>،  ثم تستدعي الدالة <code>zipWithNext()‎</code> عبرها مع تمرير دالة كوسيط وتحيل الناتج إلى المتغير <code>deltas</code>، وتطبع الناتج:<syntaxhighlight lang="kotlin">
fun main(args: Array<String>) {
fun main(args: Array<String>) {
println("hsoub".zip("12345") {x, y -> listOf(x,y) }) // [[h, 1], [s, 2], [o, 3], [u, 4], [b, 5]]
val values = listOf(1, 4, 9, 16, 25, 36)
println("hsoub".zip("wiki") {x, y -> if (x > y) x else y }) // [w, s, o, u]
val deltas = values.zipWithNext { a, b -> b - a }
 
println(deltas) // [3, 5, 7, 9, 11]
}
}
</syntaxhighlight>
</syntaxhighlight>
==انظر أيضًا==
==انظر أيضًا==
* <code>[[Kotlin/kotlin.text/toDouble|toDouble()]]</code>‎ : تحلّل الدالة <code>toDouble()</code>‎ السلسلة النصية التي استٌدعيت عبرها وتحوّلها إلى عدد من النوع <code>Double</code> وتعيد الناتج.
* <code>[[Kotlin/kotlin.text/zip|zip()]]</code>‎ : تعيد الدالة <code>zip()</code>‎ [[Kotlin/List|لائحة]] تحتوي [[Kotlin/Pair/index|أزواجًا]] (pairs) مُركّبة من حروف [[Kotlin/CharSequence/index|سلسلة الحروف]]  التي استٌدعيت عبرها ومن حروف السلسلة الأخرى المًمرّرة <code>other</code> التي لها نفس الفهرس، [[Kotlin/List|اللائحة]] المُعادة لها طول أقصر [[Kotlin/CharSequence/index|سلسلة حروف]].


*<code>[[Kotlin/text/toUpperCase|toUpperCase()]]</code>‎ : تحوّل الدالة <code>toUpperCase()</code>‎ الحرف أو السلسلة النصية التي استٌدعيت عبرها إلى حالة الأحرف الكبيرة (uppercase).
*<code>[[Kotlin/text/toUpperCase|toUpperCase()]]</code>‎ : تحوّل الدالة <code>toUpperCase()</code>‎ الحرف أو السلسلة النصية التي استٌدعيت عبرها إلى حالة الأحرف الكبيرة (uppercase).
سطر 39: سطر 47:
*<code>[[Kotlin/text/isDefined|isDefined()]]‎</code>: تعيد القيمة <code>true</code> في حال كان الحرف (Unicode code point) الذي استٌدعيت عبره مُعرّفًا في اليونيكود (Unicode).
*<code>[[Kotlin/text/isDefined|isDefined()]]‎</code>: تعيد القيمة <code>true</code> في حال كان الحرف (Unicode code point) الذي استٌدعيت عبره مُعرّفًا في اليونيكود (Unicode).
==مصادر==
==مصادر==
<span> </span>
*[http://kotlinlang.org/api/latest/jvm/stdlib/kotlin.text/zip-with-next.html صفحة الدالة text.zipWithNext()‎ في التوثيق الرسميّ للمكتبة القياسيّة في لغة Kotlin.]
*[http://kotlinlang.org/api/latest/jvm/stdlib/kotlin.text/zip.html صفحة الدالة text.zipWithNext()‎ في التوثيق الرسميّ للمكتبة القياسيّة في لغة Kotlin.]
[[تصنيف:Kotlin]]
[[تصنيف:Kotlin]]
[[تصنيف:Kotlin Method]]
[[تصنيف:Kotlin Method]]

مراجعة 07:34، 14 يوليو 2018

يختلف سلوك الدالة zipWithNext()‎ بحسب نوع وعدد الوسائط المُمرّرة (انظر فقرة البنية العامة).

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

fun CharSequence.zipWithNext(): List<Pair<Char, Char>>

بيئة التشغيل المطلوبة: Kotlin 1.2 تعيد الدالة zipWithNext()لائحة تحتوي أزواجًا (pairs) مُركّبة من حروف سلسلة الحروف  التي استٌدعيت عبرها ومن حروف السلسلة الأخرى المًمرّرة other التي عند الفهرس الموالي، اللائحة المُعادة ستكون فارغة إن كانت سلسلة حروف الأصلية تحتوي أقل من حرفين.

inline fun <R> CharSequence.zipWithNext(
    transform: (a: Char, b: Char) -> R
): List<R>

بيئة التشغيل المطلوبة: Kotlin 1.2

تعيد الدالة zipWithNext()لائحة تحتوي نتائج تطبيق الدالة المُمرّرة transform على حروف سلسلة الحروف  التي استٌدعيت عبرها وعلى حروف السلسلة الأخرى المًمرّرة other التي عند الفهرس الموالي، اللائحة المُعادة ستكون فارغة إن كانت سلسلة حروف الأصلية تحتوي أقل من حرفين.

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

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

لائحة.

أمثلة

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

تعرّف الشيفرة الآتية لائحة حروف باسم letters، ثم تستدعي الدالة zipWithNext()‎ عبرها وتحيل الناتج إلى المتغير pairs، وتطبع الناتج:

fun main(args: Array<String>) {
val letters = ('a'..'f').toList()
val pairs = letters.zipWithNext()

println(letters) // [a, b, c, d, e, f]
println(pairs) // [(a, b), (b, c), (c, d), (d, e), (e, f)]
}

استخدام الدالة zipWithNext()‎ مع السلاسل النصية مع تمرير دالة

تعرّف الشيفرة الآتية لائحة أعداد باسم values، ثم تستدعي الدالة zipWithNext()‎ عبرها مع تمرير دالة كوسيط وتحيل الناتج إلى المتغير deltas، وتطبع الناتج:

fun main(args: Array<String>) {
val values = listOf(1, 4, 9, 16, 25, 36)
val deltas = values.zipWithNext { a, b -> b - a }

println(deltas) // [3, 5, 7, 9, 11]
}

انظر أيضًا

  • toUpperCase()‎ : تحوّل الدالة toUpperCase()‎ الحرف أو السلسلة النصية التي استٌدعيت عبرها إلى حالة الأحرف الكبيرة (uppercase).
  • toBigDecimal(): تحلّل الدالة toBigDecimal()السلسلة النصية التي استٌدعيت عبرها وتحوّلها إلى عدد من النوع BigDecimal.
  • isDefined(): تعيد القيمة true في حال كان الحرف (Unicode code point) الذي استٌدعيت عبره مُعرّفًا في اليونيكود (Unicode).

مصادر