الفرق بين المراجعتين لصفحة: «Kotlin/collections/foldIndexed»
لا ملخص تعديل |
جميل-بيلوني (نقاش | مساهمات) ط مراجعة وتدقيق. |
||
سطر 1: | سطر 1: | ||
<noinclude>{{DISPLAYTITLE: الدالة <code>foldIndexed()</code> في | <noinclude>{{DISPLAYTITLE: الدالة <code>foldIndexed()</code> في Kotlin}}</noinclude> | ||
تجمع الدالة <code>foldIndexed()</code> ناتج تطبيق عملية معينة على قيمة كل عنصر من عناصر المصفوفة أو المجموعة (بدءًا من اليسار إلى اليمين) المستدعاة معها وفهرس ذلك العنصر بشكل تراكمي بالإضافة إلى القيمة الأولية إن أعطيت. | |||
==البنية العامة== | ==البنية العامة== | ||
يمكن استدعاء الدالة<code>foldIndexed()</code> | يمكن استدعاء الدالة <code>foldIndexed()</code> مع [[Kotlin/Array|المصفوفات]]:<syntaxhighlight lang="kotlin"> | ||
inline fun <T, R> Array<out T>.foldIndexed( | inline fun <T, R> Array<out T>.foldIndexed( | ||
initial: R, | initial: R, | ||
سطر 40: | سطر 40: | ||
): R | ): R | ||
</syntaxhighlight> | </syntaxhighlight>ويمكن استدعاؤها مع [[Kotlin/collections|المجموعات]]:<syntaxhighlight lang="kotlin"> | ||
inline fun <T, R> Iterable<T>.foldIndexed( | inline fun <T, R> Iterable<T>.foldIndexed( | ||
initial: R, | initial: R, | ||
operation: (index: Int, acc: R, T) -> R | operation: (index: Int, acc: R, T) -> R | ||
): R | ): R | ||
</syntaxhighlight> | </syntaxhighlight>وجود الكلمة المفتاحية <code>inline</code> يدل على أنَّ هذه الدالة مباشرة (للمزيد من التفاصيل، راجع صفحة <nowiki/>[[Kotlin/inline functions|الدوال المباشرة (inline functions)]]). | ||
==القيم المٌعادة== | ==القيم المٌعادة== | ||
يعاد الناتج النهائي التراكمي لتطبيق العملية <code>operation</code> المعطاة على كل عنصر من عناصر [[Kotlin/Array|مصفوفة]] أو [[Kotlin/collections|مجموعة]] (بدءًا من اليسار إلى اليمين) مع فهرس ذلك العنصر مضافًا إليه القيمة الأولية <code>initial</code> إن أعطيت. | |||
==أمثلة== | ==أمثلة== | ||
تعرف الشيفرة الآتية <nowiki/>[[Kotlin/Array|مصفوفة]] باسم <code>array</code> باستخدام الدالة <code>()arrayOf</code> ثمَّ تستخدم الدالة <code>()foldIndexed</code> لتطبيق عملية جمع ناتج ضرب كل عنصر مع قيمة فهرسه تراكميًّا:<syntaxhighlight lang="kotlin"> | |||
تعرف الشيفرة الآتية <nowiki/>[[Kotlin/Array|مصفوفة]] باسم <code>array</code> | |||
fun main(args: Array<String>) { | fun main(args: Array<String>) { | ||
val array = arrayOf(1,2,3,4,5,6) | val array = arrayOf(1, 2, 3, 4, 5, 6) | ||
val acc = array.foldIndexed(0) { acc , element , index -> acc + element*index } | val acc = array.foldIndexed(0) { acc, element, index -> acc + element * index } | ||
print(acc) // 719 | print(acc) // 719 | ||
} | } | ||
</syntaxhighlight> | </syntaxhighlight> | ||
==انظر أيضًا== | ==انظر أيضًا== | ||
<code>[[Kotlin/collections/ | * الدالة <code>[[Kotlin/collections/foldRightIndexed|foldRightIndexed()]]</code>: تجمع ناتج تطبيق عملية معينة على قيمة كل عنصر من عناصر المصفوفة أو المجموعة (بدءًا من اليمين إلى اليسار) المستدعاة معها وفهرس ذلك العنصر بشكل تراكمي بالإضافة إلى القيمة الأولية إن أعطيت. | ||
* الدالة <code>[[Kotlin/collections/foldRight|foldRight()]]</code>: تجمع بشكل تراكمي ناتج تطبيق عملية معيَّنة على قيمة كل عنصر من عناصر المصفوفة أو المجموعة (بدءًا من اليمين إلى اليسار) المستدعاة معها والقيمة التراكمية الحالية بالإضافة إلى القيمة الأولية إن أعطيت. | |||
<code>[[Kotlin/collections/ | |||
==مصادر== | ==مصادر== | ||
*[https://kotlinlang.org/api/latest/jvm/stdlib/kotlin.collections/fold-indexed.html الدالة | *[https://kotlinlang.org/api/latest/jvm/stdlib/kotlin.collections/fold-indexed.html صفحة الدالة foldIndexed() في التوثيق الرسميّ للمكتبة القياسيّة في لغة Kotlin.] | ||
[[تصنيف:Kotlin]] | [[تصنيف:Kotlin]] | ||
[[تصنيف:Kotlin Functions]] | [[تصنيف:Kotlin Functions]] |
مراجعة 14:33، 23 يوليو 2018
تجمع الدالة foldIndexed()
ناتج تطبيق عملية معينة على قيمة كل عنصر من عناصر المصفوفة أو المجموعة (بدءًا من اليسار إلى اليمين) المستدعاة معها وفهرس ذلك العنصر بشكل تراكمي بالإضافة إلى القيمة الأولية إن أعطيت.
البنية العامة
يمكن استدعاء الدالة foldIndexed()
مع المصفوفات:
inline fun <T, R> Array<out T>.foldIndexed(
initial: R,
operation: (index: Int, acc: R, T) -> R
): R
inline fun <R> ByteArray.foldIndexed(
initial: R,
operation: (index: Int, acc: R, Byte) -> R
): R
inline fun <R> ShortArray.foldIndexed(
initial: R,
operation: (index: Int, acc: R, Short) -> R
): R
inline fun <R> IntArray.foldIndexed(
initial: R,
operation: (index: Int, acc: R, Int) -> R
): R
inline fun <R> LongArray.foldIndexed(
initial: R,
operation: (index: Int, acc: R, Long) -> R
): R
inline fun <R> FloatArray.foldIndexed(
initial: R,
operation: (index: Int, acc: R, Float) -> R
): R
inline fun <R> DoubleArray.foldIndexed(
initial: R,
operation: (index: Int, acc: R, Double) -> R
): R
inline fun <R> BooleanArray.foldIndexed(
initial: R,
operation: (index: Int, acc: R, Boolean) -> R
): R
inline fun <R> CharArray.foldIndexed(
initial: R,
operation: (index: Int, acc: R, Char) -> R
): R
ويمكن استدعاؤها مع المجموعات:
inline fun <T, R> Iterable<T>.foldIndexed(
initial: R,
operation: (index: Int, acc: R, T) -> R
): R
وجود الكلمة المفتاحية inline
يدل على أنَّ هذه الدالة مباشرة (للمزيد من التفاصيل، راجع صفحة الدوال المباشرة (inline functions)).
القيم المٌعادة
يعاد الناتج النهائي التراكمي لتطبيق العملية operation
المعطاة على كل عنصر من عناصر مصفوفة أو مجموعة (بدءًا من اليسار إلى اليمين) مع فهرس ذلك العنصر مضافًا إليه القيمة الأولية initial
إن أعطيت.
أمثلة
تعرف الشيفرة الآتية مصفوفة باسم array
باستخدام الدالة ()arrayOf
ثمَّ تستخدم الدالة ()foldIndexed
لتطبيق عملية جمع ناتج ضرب كل عنصر مع قيمة فهرسه تراكميًّا:
fun main(args: Array<String>) {
val array = arrayOf(1, 2, 3, 4, 5, 6)
val acc = array.foldIndexed(0) { acc, element, index -> acc + element * index }
print(acc) // 719
}
انظر أيضًا
- الدالة
foldRightIndexed()
: تجمع ناتج تطبيق عملية معينة على قيمة كل عنصر من عناصر المصفوفة أو المجموعة (بدءًا من اليمين إلى اليسار) المستدعاة معها وفهرس ذلك العنصر بشكل تراكمي بالإضافة إلى القيمة الأولية إن أعطيت. - الدالة
foldRight()
: تجمع بشكل تراكمي ناتج تطبيق عملية معيَّنة على قيمة كل عنصر من عناصر المصفوفة أو المجموعة (بدءًا من اليمين إلى اليسار) المستدعاة معها والقيمة التراكمية الحالية بالإضافة إلى القيمة الأولية إن أعطيت.