الدالة text.associateByTo() في لغة Kotlin
تعيد الدالة associateByTo() قاموسا متغيرا (mutable map) يحتوي أزواجًا من "مفتاح/قيمة"، إذ القيمة هي عناصر سلسلة الحروف التي استُدعيت عبرها، والمفتاح هو الناتج المعاد من تمرير تلك العناصر إلى الدالة keySelector.
إن كان لعنصرين نفس المفتاح (key) بعد تطبيق الدالة keySelector، فإنَّ الأخير هو الذي سيُضاف إلى القاموس.
البنية العامة
inline fun <K, M : MutableMap<in K, in Char>> CharSequence.associateByTo(
destination: M,
keySelector: (Char) -> K
): M
ستعيد الدالة associateByTo() القاموس المتغير destination الذي يحتوي على أزواج من "قيمة/مفتاح"، إذ القيمة هي عناصر سلسلة الحروف، والمفتاح هو الناتج المعاد من تمرير تلك العناصر إلى الدالة keySelector:
inline fun <K, V, M : MutableMap<in K, in V>> CharSequence.associateByTo(
destination: M,
keySelector: (Char) -> K,
valueTransform: (Char) -> V
): M
إن استدعيت الدالة associateByTo() مع سلسلة حروف، فستعيد القاموس المتغير destination الذي يحتوي على أزواج من "قيمة/مفتاح"، إذ القيمة هي عناصر سلسلة الحروف المعطاة بواسطة valueTransform، والمفتاح هو الناتج المعاد من تمرير تلك العناصر إلى الدالة keySelector:
يلاحظ وجود الكلمة المفتاحية inline يدل على أنَّ هذه الدالة مباشرة (للمزيد من التفاصيل راجع توثيق الدوال المباشرة (inline functions)).
القيم المعادة
أمثلة
استخدام الدالة ()associateByTo مع سلسلة نصية
تعرِّف الشيفرة الآتية سلسلة نصية باسم str، ثمَّ تنشئ قاموسا متغيرا باسم map، ثم تمرّر الدالة ()func (التي تحول الحروف إلى الحالة الكبيرة [UpperCase]) والقاموس المتغير mapإلى ()associateByTo، ثمَّ تطبع الناتج:
fun main(args: Array<String>) {
val str = "hsoub"
val map = mutableMapOf<Char, Char>()
val func: (Char) -> Char = {it.toUpperCase()}
str.associateByTo(map,func)
println(map) // {H=h, S=s, O=o, U=u, B=b}
}
استخدام الدالة ()associateByTo مع تمرير دالتين
تعرِّف الشيفرة الآتية سلسلة نصية باسم str، ثمَّ تنشئ قاموسا متغيرا باسم map، ثم تمرّر الدالة ()func (التي تحول الحروف إلى الحالة الكبيرة [UpperCase])، والدالة ()func2 (التي تحول الحروف إلى الحالة الصغيرة [LowerCase])، إضافة إلى القاموس المتغير mapإلى ()associateByTo، ثمَّ تطبع الناتج:
fun main(args: Array<String>) {
val str = "hsoub ACADEMY"
val map = mutableMapOf<Char, Char>()
val func: (Char) -> Char = {it.toUpperCase()}
val func2: (Char) -> Char = {it.toLowerCase()}
str.associateByTo(map,func, func2)
println(map) // {H=h, S=s, O=o, U=u, B=b, = , A=a, C=c, D=d, E=e, M=m, Y=y}
}
انظر أيضًا
associateBy(): تعيد قاموسًا (map) يحتوي عناصر سلسلة الحروف التي استُدعيت عبرها مفهرسةً بقيمة المفتاح المعاد من تمرير تلك العناصر إلى الدالةkeySelector.all(): تعيد الدالةall()القيمةtrueإن كانت كل الحروف تحقق الشرط المنطقي المُمرّرpredicate.asSequence(): تنشئ كائنًا من الصنفSequenceوالذي يُغلّف سلسلة الحروف التي استُدعيت عبرها، لأجل استعمالها في الحلقات التكرارية.