الفرق بين المراجعتين لصفحة: «Kotlin/collections/groupByTo»
أنشأ الصفحة ب'<noinclude>{{DISPLAYTITLE: الدالة <code>groupByTo()</code> في لغة Kotlin}}</noinclude> تعيد الدالة<code>groupByTo()</code> Kotlin/collection...' |
لا ملخص تعديل |
||
سطر 5: | سطر 5: | ||
==البنية العامة== | ==البنية العامة== | ||
<syntaxhighlight lang="kotlin"> | <syntaxhighlight lang="kotlin"> | ||
inline fun <T, K> Array<out T>. | inline fun <T, K, M : MutableMap<in K, MutableList<T>>> Array<out T>.groupByTo( | ||
destination: M, | |||
keySelector: (T) -> K | keySelector: (T) -> K | ||
): | ): M | ||
inline fun <K, M : MutableMap<in K, MutableList<Byte>>> ByteArray.groupByTo( | |||
destination: M, | |||
keySelector: (Byte) -> K | keySelector: (Byte) -> K | ||
): | ): M | ||
inline fun <K, M : MutableMap<in K, MutableList<Short>>> ShortArray.groupByTo( | |||
destination: M, | |||
keySelector: (Short) -> K | keySelector: (Short) -> K | ||
): | ): M | ||
inline fun <K, M : MutableMap<in K, MutableList<Int>>> IntArray.groupByTo( | |||
destination: M, | |||
keySelector: (Int) -> K | keySelector: (Int) -> K | ||
): | ): M | ||
inline fun <K, M : MutableMap<in K, MutableList<Long>>> LongArray.groupByTo( | |||
destination: M, | |||
keySelector: (Long) -> K | keySelector: (Long) -> K | ||
): | ): M | ||
inline fun <K, M : MutableMap<in K, MutableList<Float>>> FloatArray.groupByTo( | |||
destination: M, | |||
keySelector: (Float) -> K | keySelector: (Float) -> K | ||
): | ): M | ||
inline fun <K, M : MutableMap<in K, MutableList<Double>>> DoubleArray.groupByTo( | |||
destination: M, | |||
keySelector: (Double) -> K | keySelector: (Double) -> K | ||
): | ): M | ||
inline fun <K, M : MutableMap<in K, MutableList<Boolean>>> BooleanArray.groupByTo( | |||
destination: M, | |||
keySelector: (Boolean) -> K | keySelector: (Boolean) -> K | ||
): | ): M | ||
inline fun <K, M : MutableMap<in K, MutableList<Char>>> CharArray.groupByTo( | |||
destination: M, | |||
keySelector: (Char) -> K | keySelector: (Char) -> K | ||
): | ): M | ||
</syntaxhighlight>في حال استدعاء الدالة<code>groupBy()</code> على [[Kotlin/Array|المصفوفات]] مع تمرير | </syntaxhighlight>في حال استدعاء الدالة<code>groupBy()</code> على [[Kotlin/Array|المصفوفات]] مع تمرير معاملين <code>destination</code> و<code>keySelector</code> فإنّها تُجمّع عناصر [[Kotlin/Array|المصفوفة]] الأصلية وتضيفها إلى [[Kotlin/collections/Map|القاموس]].المُمرّر <code>destination</code> حيث مفاتيحه تعيدها الدالة الممرّرة <code>keySelector()</code> مُطبّقة على كل عناصر [[Kotlin/Array|المصفوفة]] وقيمه [[Kotlin/collections/List|لوائح]] تضم العناصر المقابلة. ثم تعيد القاموس<code>destination</code>:<syntaxhighlight lang="kotlin"> | ||
inline fun <T, K, V> Array<out T>. | inline fun <T, K, V, M : MutableMap<in K, MutableList<V>>> Array<out T>.groupByTo( | ||
destination: M, | |||
keySelector: (T) -> K, | keySelector: (T) -> K, | ||
valueTransform: (T) -> V | valueTransform: (T) -> V | ||
): | ): M | ||
inline fun <K, V, M : MutableMap<in K, MutableList<V>>> ByteArray.groupByTo( | |||
destination: M, | |||
keySelector: (Byte) -> K, | keySelector: (Byte) -> K, | ||
valueTransform: (Byte) -> V | valueTransform: (Byte) -> V | ||
): | ): M | ||
inline fun <K, V, M : MutableMap<in K, MutableList<V>>> ShortArray.groupByTo( | |||
destination: M, | |||
keySelector: (Short) -> K, | keySelector: (Short) -> K, | ||
valueTransform: (Short) -> V | valueTransform: (Short) -> V | ||
): | ): M | ||
inline fun <K, V, M : MutableMap<in K, MutableList<V>>> IntArray.groupByTo( | |||
destination: M, | |||
keySelector: (Int) -> K, | keySelector: (Int) -> K, | ||
valueTransform: (Int) -> V | valueTransform: (Int) -> V | ||
): | ): M | ||
inline fun <K, V, M : MutableMap<in K, MutableList<V>>> LongArray.groupByTo( | |||
destination: M, | |||
keySelector: (Long) -> K, | keySelector: (Long) -> K, | ||
valueTransform: (Long) -> V | valueTransform: (Long) -> V | ||
): | ): M | ||
inline fun <K, V, M : MutableMap<in K, MutableList<V>>> FloatArray.groupByTo( | |||
destination: M, | |||
keySelector: (Float) -> K, | keySelector: (Float) -> K, | ||
valueTransform: (Float) -> V | valueTransform: (Float) -> V | ||
): | ): M | ||
inline fun <K, V, M : MutableMap<in K, MutableList<V>>> DoubleArray.groupByTo( | |||
destination: M, | |||
keySelector: (Double) -> K, | keySelector: (Double) -> K, | ||
valueTransform: (Double) -> V | valueTransform: (Double) -> V | ||
): | ): M | ||
inline fun <K, V, M : MutableMap<in K, MutableList<V>>> BooleanArray.groupByTo( | |||
destination: M, | |||
keySelector: (Boolean) -> K, | keySelector: (Boolean) -> K, | ||
valueTransform: (Boolean) -> V | valueTransform: (Boolean) -> V | ||
): | ): M | ||
inline fun <K, V, M : MutableMap<in K, MutableList<V>>> CharArray.groupByTo( | |||
destination: M, | |||
keySelector: (Char) -> K, | keySelector: (Char) -> K, | ||
valueTransform: (Char) -> V | valueTransform: (Char) -> V | ||
): | ): M | ||
</syntaxhighlight>في حال استدعاء الدالة<code>groupBy()</code> على [[Kotlin/Array|المصفوفات]] مع تمرير | </syntaxhighlight>في حال استدعاء الدالة<code>groupBy()</code> على [[Kotlin/Array|المصفوفات]] مع تمرير ثلاث معاملات <code>destination</code> و <code>valueTransform</code> و <code>keySelector</code> فإنّها تُجمّع العناصر المعادة من قبل الدالة <code>valueTransform()</code> مُطبّقة على كل عناصر [[Kotlin/Array|المصفوفة]] وتربطها بالمفتاح الذي تعيده الدالة<code>keySelector()</code> مطبقة على على عناصر [[Kotlin/Array|المصفوفة]] وتضيفها إلى [[Kotlin/collections/Map|القاموس]] المُمرّر <code>destination</code> حيث كل مفتاح مرتبط [[Kotlin/collections/List|بلائحة]] العناصر المقابلة. ثم تعيد [[Kotlin/collections/Map|القاموس]] <code>destination</code>:<syntaxhighlight lang="kotlin"> | ||
inline fun <T, K> Iterable<T>.groupBy( | inline fun <T, K> Iterable<T>.groupBy( | ||
keySelector: (T) -> K | keySelector: (T) -> K | ||
سطر 89: | سطر 107: | ||
تعرف الشيفرة الآتية <nowiki/>[[Kotlin/Array|مصفوفة]] باسم <code>array</code> مكونة من ست سلاسل نصية باستخدام الدالة <code>()arrayOf</code>، ثم تستخدم الدالة <code>()groupByTo</code> على <code>array</code> بتمرير الدالة التي تعيد طول السلسلة النصية المُمرّرة، وتجمّع عناصر <code>array</code> التي لها نفس الطول في [[Kotlin/collections/Map|قاموس]]، ثم تطبع [[Kotlin/collections/Map|القاموس]]:<syntaxhighlight lang="kotlin"> | تعرف الشيفرة الآتية <nowiki/>[[Kotlin/Array|مصفوفة]] باسم <code>array</code> مكونة من ست سلاسل نصية باستخدام الدالة <code>()arrayOf</code>، ثم تستخدم الدالة <code>()groupByTo</code> على <code>array</code> بتمرير الدالة التي تعيد طول السلسلة النصية المُمرّرة، وتجمّع عناصر <code>array</code> التي لها نفس الطول في [[Kotlin/collections/Map|قاموس]]، ثم تطبع [[Kotlin/collections/Map|القاموس]]:<syntaxhighlight lang="kotlin"> | ||
fun main(args: Array<String>) { | fun main(args: Array<String>) { | ||
val array = arrayOf("a", "abc", "ab", "def","avde" ,"abcd") | |||
val map: MutableMap<Int, MutableList<String>> = mutableMapOf() // انشاء قاموس فارغ | |||
print(array.groupByTo ( map, { it.length })) // {1=[a], 3=[abc, def], 2=[ab], 4=[avde, abcd]} | |||
} | } | ||
</syntaxhighlight> | </syntaxhighlight> | ||
سطر 106: | سطر 125: | ||
<code>[[Kotlin/collections/groupByTo|groupByTo()]]</code>: تضيف إلى [[Kotlin/collections/Map|القاموس]] المُمرّر عناصر [[Kotlin/Array|المصفوفة]] أو [[Kotlin/collections|المجموعة]] التي استُدعيت عبرها حيث مفاتيحه تعيدها الدالة المُمرّرة <code>keySelector</code> وقيمه لوائحُ تضم عناصر [[Kotlin/Array|المصفوفة]] أو [[Kotlin/collections|المجموعة]] (أو ناتج تمرير عناصر [[Kotlin/Array|المصفوفة]] أو [[Kotlin/collections|المجموعة]] على الدالة <code>valueTransform</code> في حال تمريرها). | <code>[[Kotlin/collections/groupByTo|groupByTo()]]</code>: تضيف إلى [[Kotlin/collections/Map|القاموس]] المُمرّر عناصر [[Kotlin/Array|المصفوفة]] أو [[Kotlin/collections|المجموعة]] التي استُدعيت عبرها حيث مفاتيحه تعيدها الدالة المُمرّرة <code>keySelector</code> وقيمه لوائحُ تضم عناصر [[Kotlin/Array|المصفوفة]] أو [[Kotlin/collections|المجموعة]] (أو ناتج تمرير عناصر [[Kotlin/Array|المصفوفة]] أو [[Kotlin/collections|المجموعة]] على الدالة <code>valueTransform</code> في حال تمريرها). | ||
==مصادر== | ==مصادر== | ||
[https://kotlinlang.org/api/latest/jvm/stdlib/kotlin.collections/group-by-to.html الدالة groupByTo() في التوثيق الرسمي للمكتبة القياسية في لغة Kotlin] | |||
[[تصنيف:Kotlin]] | [[تصنيف:Kotlin]] | ||
[[تصنيف:Kotlin Functions]] | [[تصنيف:Kotlin Functions]] |
مراجعة 17:20، 19 مايو 2018
تعيد الدالةgroupByTo()
قاموسًا يُجمّع عناصر المصفوفة أو المجموعة التي استُدعيت عبرها حيث مفاتيحه تعيدها الدالة المُمرّرة keySelector
وقيمه لوائحُ تضم عناصر المصفوفة أو المجموعة (أو ناتج تمرير عناصر المصفوفة أو المجموعة على الدالة valueTransform
في حال تمريرها).
القاموس المُعاد يحافظ على على ترتيب التكرار (entry iteration order) للمفاتيح الناتجة عن المصفوفة أو المجموعة الأصلية.
البنية العامة
inline fun <T, K, M : MutableMap<in K, MutableList<T>>> Array<out T>.groupByTo(
destination: M,
keySelector: (T) -> K
): M
inline fun <K, M : MutableMap<in K, MutableList<Byte>>> ByteArray.groupByTo(
destination: M,
keySelector: (Byte) -> K
): M
inline fun <K, M : MutableMap<in K, MutableList<Short>>> ShortArray.groupByTo(
destination: M,
keySelector: (Short) -> K
): M
inline fun <K, M : MutableMap<in K, MutableList<Int>>> IntArray.groupByTo(
destination: M,
keySelector: (Int) -> K
): M
inline fun <K, M : MutableMap<in K, MutableList<Long>>> LongArray.groupByTo(
destination: M,
keySelector: (Long) -> K
): M
inline fun <K, M : MutableMap<in K, MutableList<Float>>> FloatArray.groupByTo(
destination: M,
keySelector: (Float) -> K
): M
inline fun <K, M : MutableMap<in K, MutableList<Double>>> DoubleArray.groupByTo(
destination: M,
keySelector: (Double) -> K
): M
inline fun <K, M : MutableMap<in K, MutableList<Boolean>>> BooleanArray.groupByTo(
destination: M,
keySelector: (Boolean) -> K
): M
inline fun <K, M : MutableMap<in K, MutableList<Char>>> CharArray.groupByTo(
destination: M,
keySelector: (Char) -> K
): M
في حال استدعاء الدالةgroupBy()
على المصفوفات مع تمرير معاملين destination
وkeySelector
فإنّها تُجمّع عناصر المصفوفة الأصلية وتضيفها إلى القاموس.المُمرّر destination
حيث مفاتيحه تعيدها الدالة الممرّرة keySelector()
مُطبّقة على كل عناصر المصفوفة وقيمه لوائح تضم العناصر المقابلة. ثم تعيد القاموسdestination
:
inline fun <T, K, V, M : MutableMap<in K, MutableList<V>>> Array<out T>.groupByTo(
destination: M,
keySelector: (T) -> K,
valueTransform: (T) -> V
): M
inline fun <K, V, M : MutableMap<in K, MutableList<V>>> ByteArray.groupByTo(
destination: M,
keySelector: (Byte) -> K,
valueTransform: (Byte) -> V
): M
inline fun <K, V, M : MutableMap<in K, MutableList<V>>> ShortArray.groupByTo(
destination: M,
keySelector: (Short) -> K,
valueTransform: (Short) -> V
): M
inline fun <K, V, M : MutableMap<in K, MutableList<V>>> IntArray.groupByTo(
destination: M,
keySelector: (Int) -> K,
valueTransform: (Int) -> V
): M
inline fun <K, V, M : MutableMap<in K, MutableList<V>>> LongArray.groupByTo(
destination: M,
keySelector: (Long) -> K,
valueTransform: (Long) -> V
): M
inline fun <K, V, M : MutableMap<in K, MutableList<V>>> FloatArray.groupByTo(
destination: M,
keySelector: (Float) -> K,
valueTransform: (Float) -> V
): M
inline fun <K, V, M : MutableMap<in K, MutableList<V>>> DoubleArray.groupByTo(
destination: M,
keySelector: (Double) -> K,
valueTransform: (Double) -> V
): M
inline fun <K, V, M : MutableMap<in K, MutableList<V>>> BooleanArray.groupByTo(
destination: M,
keySelector: (Boolean) -> K,
valueTransform: (Boolean) -> V
): M
inline fun <K, V, M : MutableMap<in K, MutableList<V>>> CharArray.groupByTo(
destination: M,
keySelector: (Char) -> K,
valueTransform: (Char) -> V
): M
في حال استدعاء الدالةgroupBy()
على المصفوفات مع تمرير ثلاث معاملات destination
و valueTransform
و keySelector
فإنّها تُجمّع العناصر المعادة من قبل الدالة valueTransform()
مُطبّقة على كل عناصر المصفوفة وتربطها بالمفتاح الذي تعيده الدالةkeySelector()
مطبقة على على عناصر المصفوفة وتضيفها إلى القاموس المُمرّر destination
حيث كل مفتاح مرتبط بلائحة العناصر المقابلة. ثم تعيد القاموس destination
:
inline fun <T, K> Iterable<T>.groupBy(
keySelector: (T) -> K
): Map<K, List<T>>
في حال استدعاء الدالةgroupBy()
على المجموعات مع تمرير معامل واحد keySelector
فإنّها تُجمّع عناصر المصفوفة الأصلية في قاموس.حيث مفاتيحه تعيدها الدالة الممرّرة keySelector()
مُطبّقة على كل عناصر المصفوفة وقيمه لائحة تضم العناصر المقابلة.
inline fun <T, K, V> Iterable<T>.groupBy(
keySelector: (T) -> K,
valueTransform: (T) -> V
): Map<K, List<V>>
في حال استدعاء الدالةgroupBy()
على المجموعات مع تمرير معاملين valueTransform
و keySelector
فإنّها تُجمّع العناصر المعادة من قبل الدالة valueTransform()
مُطبّقة على كل عناصر المصفوفة وتربطها بالمفتاح الذي تعيده الدالةkeySelector()
مطبقة على على عناصر المجموعة وتعيد قاموسًا حيث كل مفتاح مرتبط بلائحة العناصر المقابلة.
يُلاحَظ وجود الكلمة المفتاحية inline
للدلالة على أن هذه الدالة مباشرة، وللمزيد من التفاصيل راجع توثيق الدوال المباشرة (inline functions).
القيم المٌعادة
قاموس يُجمّع عناصر المصفوفة أو المجموعة التي استُدعيت عبرها حيث مفاتيحه تعيدها الدالة المُمرّرة keySelector
وقيمه لوائحُ تضم عناصر المصفوفة أو المجموعة (أو ناتج تمرير عناصر المصفوفة أو المجموعة على الدالة valueTransform
في حال تمريرها).
أمثلة
استخدام الدالة ()groupByTo
مع المصفوفات مع تمرير معامل واحد
تعرف الشيفرة الآتية مصفوفة باسم array
مكونة من ست سلاسل نصية باستخدام الدالة ()arrayOf
، ثم تستخدم الدالة ()groupByTo
على array
بتمرير الدالة التي تعيد طول السلسلة النصية المُمرّرة، وتجمّع عناصر array
التي لها نفس الطول في قاموس، ثم تطبع القاموس:
fun main(args: Array<String>) {
val array = arrayOf("a", "abc", "ab", "def","avde" ,"abcd")
val map: MutableMap<Int, MutableList<String>> = mutableMapOf() // انشاء قاموس فارغ
print(array.groupByTo ( map, { it.length })) // {1=[a], 3=[abc, def], 2=[ab], 4=[avde, abcd]}
}
استخدام الدالة ()groupByTo
مع المصفوفات مع تمرير مُعاملين
تعرف الشيفرة الآتية مصفوفة باسم array
مكونة من ست سلاسل نصية باستخدام الدالة ()arrayOf
، ثم تستخدم الدالة ()groupByTo
على array
بتمرير دالة تعيد طول السلسلة النصية المُمرّرة ودالة تعيد المصفوفة بالحروف الكبيرة، وتجمّع عناصر array
التي لها نفس الطول في قاموس بتحويلها إلى الحروف الكبيرة، ثم تطبع القاموس:
fun main(args: Array<String>) {
val array = arrayOf("a", "abc", "ab", "def","avde" ,"abcd")
print(array.groupBy( { it.length }, {it.toUpperCase()} )) // {1=[A], 3=[ABC, DEF], 2=[AB],
// 4=[AVDE, ABCD]}
}
انظر أيضًا
groupByTo()
: تضيف إلى القاموس المُمرّر عناصر المصفوفة أو المجموعة التي استُدعيت عبرها حيث مفاتيحه تعيدها الدالة المُمرّرة keySelector
وقيمه لوائحُ تضم عناصر المصفوفة أو المجموعة (أو ناتج تمرير عناصر المصفوفة أو المجموعة على الدالة valueTransform
في حال تمريرها).
مصادر
الدالة groupByTo() في التوثيق الرسمي للمكتبة القياسية في لغة Kotlin