الفرق بين المراجعتين لصفحة: «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/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"> | ||
fun CharSequence.zipWithNext(): List<Pair<Char, Char>> | |||
): List<Pair<Char, Char>> | </syntaxhighlight>'''بيئة التشغيل المطلوبة: Kotlin 1.2''' | ||
</syntaxhighlight>تعيد الدالة <code>zipWithNext()</code> [[Kotlin/List|لائحة]] تحتوي [[Kotlin/Pair/index|أزواجًا]] (pairs) مُركّبة من حروف [[Kotlin/CharSequence/index|سلسلة الحروف]] التي استٌدعيت عبرها ومن حروف السلسلة الأخرى المًمرّرة <code>other</code> التي | |||
inline fun < | تعيد الدالة <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 <R> CharSequence.zipWithNext( | |||
transform: (a: Char, b: Char) -> | transform: (a: Char, b: Char) -> R | ||
): List< | ): List<R> | ||
</syntaxhighlight>تعيد الدالة <code>zipWithNext()</code> [[Kotlin/List|لائحة]] تحتوي نتائج تطبيق الدالة المُمرّرة <code>transform</code> على حروف [[Kotlin/CharSequence/index|سلسلة الحروف]] التي استٌدعيت عبرها وعلى حروف السلسلة الأخرى المًمرّرة <code>other</code> التي | </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> مع السلاسل النصية === | ||
تعرّف الشيفرة الآتية [[Kotlin/List|لائحة]] حروف باسم <code>letters،</code> ثم تستدعي الدالة <code>zipWithNext()</code> عبرها وتحيل الناتج إلى المتغير <code>pairs</code>، وتطبع الناتج:<syntaxhighlight lang="kotlin"> | |||
fun main(args: Array<String>) { | fun main(args: Array<String>) { | ||
val letters = ('a'..'f').toList() | |||
println( | val pairs = letters.zipWithNext() | ||
println( | |||
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> مع السلاسل النصية مع تمرير دالة=== | ||
تعرّف الشيفرة الآتية [[Kotlin/List|لائحة]] أعداد باسم <code>values</code>، ثم تستدعي الدالة <code>zipWithNext()</code> عبرها مع تمرير دالة كوسيط وتحيل الناتج إلى المتغير <code>deltas</code>، وتطبع الناتج:<syntaxhighlight lang="kotlin"> | |||
fun main(args: Array<String>) { | 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] | |||
} | } | ||
</syntaxhighlight> | </syntaxhighlight> | ||
==انظر أيضًا== | ==انظر أيضًا== | ||
* <code>[[Kotlin/kotlin.text/ | * <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). | ||
==مصادر== | ==مصادر== | ||
*[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]
}
انظر أيضًا
zip()
: تعيد الدالةzip()
لائحة تحتوي أزواجًا (pairs) مُركّبة من حروف سلسلة الحروف التي استٌدعيت عبرها ومن حروف السلسلة الأخرى المًمرّرةother
التي لها نفس الفهرس، اللائحة المُعادة لها طول أقصر سلسلة حروف.
toUpperCase()
: تحوّل الدالةtoUpperCase()
الحرف أو السلسلة النصية التي استٌدعيت عبرها إلى حالة الأحرف الكبيرة (uppercase).toBigDecimal()
: تحلّل الدالةtoBigDecimal()
السلسلة النصية التي استٌدعيت عبرها وتحوّلها إلى عدد من النوعBigDecimal
.
isDefined()
: تعيد القيمةtrue
في حال كان الحرف (Unicode code point) الذي استٌدعيت عبره مُعرّفًا في اليونيكود (Unicode).