الدالة CharSequence.fold()‎ في Kotlin

من موسوعة حسوب

تجمِّع الدالة fold()‎ تراكميًّا ناتج تطبيق عملية معينة على كل محرف من محارف السلسلة المستدعاة معها (من اليسار إلى اليمين) والقيمة التراكمية الحالية مع قيمة أولية إن أعطيت.

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

inline fun <R> CharSequence.fold(
    initial: R, 
    operation: (acc: R, Char) -> R
): R

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

المعاملات

initial

قيمة أولية يراد إضافتها مع ناتج تطبيق الدالة operation على أول محرف من محارف السلسلة لبدء عملية التجميع.

operation

دالةٌ تمثل العملية المراد تطبيقها على كل محرف من محارف السلسلة، إذ يمرَّر إليها القيمة المجمعة الحالية acc وكل محرف من محارف السلسلة char، وتعيد القيمة المجمَّعة التالية acc.

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

تعاد القيمة المجمَّعة النهائية الناتجة عن تطبيق العملية operation بشكل تراكمي على كل محرف من محارف سلسلة المحارف المعطاة مع إضافة قيمة المعامل initial إلى ناتج تطبيق العملية أول مرة.

أمثلة

مثالٌ على استعمال الدالة ()fold:

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

    val max = str.fold('A') { max, element -> if (max > element) max else element }
    print(max) // w
}

انظر أيضًا

  • الدالة foldRight()‎: تجمِّع تراكميًّا ناتج تطبيق عملية معينة على كل محرف من محارف السلسلة المستدعاة معها (بدءًا من اليمين إلى اليسار) والقيمة التراكمية الحالية مع قيمة أولية إن أعطيت.  
  • الدالة foldIndexed(): تجمِّع تراكميًّا ناتج تطبيق عملية معينة على فهرس كل محرف من محارف السلسلة المستدعاة معها (من اليسار إلى اليمين) وقيمته والقيمة التراكمية الحالية مع قيمة أولية إن أعطيت.
  • الدالة reduce(): قيمة محرف بدءًا من المحرف الأول عبر تطبيق عملية معينة من يسار سلسلة المحارف المعطاة إلى يمينها على القيمة المتراكمة الحالية وعلى الحرف التالي ثم تُعيد قيمة المحرف النهائي الناتج.
  • الدالة filter()‎: ترشِّح محارف سلسلة المحارف أو السلسلة النصية المعطاة بناءً على قيمة المحرف التي تحقِّق شرطًا معيَّنًا.

مصادر