الفرق بين المراجعتين لصفحة: «Kotlin/collections/plus»
ط استبدال النص - 'Kotlin Functions' ب'Kotlin Function' |
جميل-بيلوني (نقاش | مساهمات) طلا ملخص تعديل |
||
سطر 13: | سطر 13: | ||
element: Boolean | element: Boolean | ||
): BooleanArray | ): BooleanArray | ||
</syntaxhighlight>وإن استدعيت هذه الدالة مع [[Kotlin/Array|المصفوفات]] مع تمرير [[Kotlin/collections|مجموعة]] | </syntaxhighlight>وإن استدعيت هذه الدالة مع [[Kotlin/Array|المصفوفات]] مع تمرير [[Kotlin/collections|مجموعة]] كمعامل، فستعيد [[Kotlin/Array|مصفوفة]] تضم جميع عناصر المصفوفة التي استدعيت معها إضافةً إلى عناصر تلك [[Kotlin/collections|المجموعة]] المعطاة:<syntaxhighlight lang="kotlin"> | ||
operator fun <T> Array<T>.plus( | operator fun <T> Array<T>.plus( | ||
elements: Collection<T> | elements: Collection<T> | ||
سطر 41: | سطر 41: | ||
elements: Collection<Char> | elements: Collection<Char> | ||
): CharArray | ): CharArray | ||
</syntaxhighlight>وإن استدعيت هذه الدالة مع [[Kotlin/Array|المصفوفات]] مع تمرير [[Kotlin/Array|مصفوفة]] | </syntaxhighlight>وإن استدعيت هذه الدالة مع [[Kotlin/Array|المصفوفات]] مع تمرير [[Kotlin/Array|مصفوفة]] كمعامل، فستعيد [[Kotlin/Array|مصفوفة]] تضم جميع عناصر المصفوفة التي استدعيت معها إضافةً إلى جميع عناصر [[Kotlin/Array|المصفوفة]] المُمرّرة:<syntaxhighlight lang="kotlin"> | ||
operator fun <T> Array<T>.plus( | operator fun <T> Array<T>.plus( | ||
elements: Array<out T> | elements: Array<out T> | ||
سطر 62: | سطر 62: | ||
</syntaxhighlight>وإن استدعيت هذه الدالة مع [[Kotlin/collections|المجموعات]]، فستعيد [[Kotlin/List|قائمةً]] تضم جميع عناصر [[Kotlin/collections|المجموعة]] التي استدعيت معها إضافة إلى العنصر المُمرّر:<syntaxhighlight lang="kotlin"> | </syntaxhighlight>وإن استدعيت هذه الدالة مع [[Kotlin/collections|المجموعات]]، فستعيد [[Kotlin/List|قائمةً]] تضم جميع عناصر [[Kotlin/collections|المجموعة]] التي استدعيت معها إضافة إلى العنصر المُمرّر:<syntaxhighlight lang="kotlin"> | ||
operator fun <T> Iterable<T>.plus(element: T): List<T> | |||
operator fun <T> Collection<T>.plus(element: T): List<T> | |||
</syntaxhighlight>وإن استدعيت هذه الدالة مع [[Kotlin/collections|المجموعات]] مع تمرير [[Kotlin/Array|مصفوفة]] كمعامل، فستعيد [[Kotlin/List|قائمة]] تضم جميع عناصر [[Kotlin/collections|المجموعة]] التي استدعيت معها إضافةً إلى عناصر [[Kotlin/Array|المصفوفة]] المُمرّرة:<syntaxhighlight lang="kotlin"> | |||
</syntaxhighlight>وإن استدعيت هذه الدالة مع [[Kotlin/collections|المجموعات]] مع تمرير [[Kotlin/Array|مصفوفة]] | |||
operator fun <T> Iterable<T>.plus( | operator fun <T> Iterable<T>.plus( | ||
elements: Array<out T> | elements: Array<out T> | ||
سطر 72: | سطر 71: | ||
elements: Array<out T> | elements: Array<out T> | ||
): List<T> | ): List<T> | ||
</syntaxhighlight>وإن استدعيت هذه الدالة مع [[Kotlin/collections|المجموعات]] مع تمرير [[Kotlin/Array|مجموعة]] | </syntaxhighlight>وإن استدعيت هذه الدالة مع [[Kotlin/collections|المجموعات]] مع تمرير [[Kotlin/Array|مجموعة]] كمعامل، فستعيد [[Kotlin/List|قائمة]] تضم جميع عناصر [[Kotlin/collections|المجموعة]] التي استدعيت معها إضافةً إلى عناصر [[Kotlin/Array|المجموعة]] المُمرّرة:<syntaxhighlight lang="kotlin"> | ||
operator fun <T> Iterable<T>.plus( | operator fun <T> Iterable<T>.plus( | ||
elements: Iterable<T> | elements: Iterable<T> | ||
سطر 79: | سطر 78: | ||
elements: Iterable<T> | elements: Iterable<T> | ||
): List<T> | ): List<T> | ||
</syntaxhighlight>وإن استدعيت هذه الدالة مع [[Kotlin/collections|المجموعات]] مع تمرير [[Kotlin/sequence|سلسلة]] | </syntaxhighlight>وإن استدعيت هذه الدالة مع [[Kotlin/collections|المجموعات]] مع تمرير [[Kotlin/sequence|سلسلة]] كمعامل، فستعيد [[Kotlin/List|قائمة]] تضم جميع عناصر [[Kotlin/collections|المجموعة]] التي استدعيت معها إضافةً إلى عناصر [[Kotlin/Array|السلسلة]] المُمرّرة:<syntaxhighlight lang="kotlin"> | ||
operator fun <T> Iterable<T>.plus( | operator fun <T> Iterable<T>.plus( | ||
elements: Sequence<T> | elements: Sequence<T> | ||
سطر 119: | سطر 118: | ||
): Map<K, V> | ): Map<K, V> | ||
</syntaxhighlight>وجود الكلمة المفتاحية <code>inline</code> يدل على أنَّ هذه الدالة مباشرة (للمزيد من التفاصيل، راجع صفحة [[Kotlin/inline functions|الدوال المباشرة (inline functions)]]). | </syntaxhighlight>وجود الكلمة المفتاحية <code>inline</code> يدل على أنَّ هذه الدالة مباشرة (للمزيد من التفاصيل، راجع صفحة [[Kotlin/inline functions|الدوال المباشرة (inline functions)]]). | ||
==المعاملات== | |||
=== <code>element</code> === | |||
العنصر المراد إضافته. | |||
=== <code>elements</code> === | |||
العناصر المراد إضافتها. | |||
=== <code>pair</code> === | |||
الزوج المراد إضافته إلى [[Kotlin/collections/Map|الخريطة]] المعطاة. | |||
=== <code>pairs</code> === | |||
الأزواج المراد إضافتها إلى [[Kotlin/collections/Map|الخريطة]] المعطاة. | |||
=== <code>map</code> === | |||
[[Kotlin/collections/Map|الخريطة]] التي يراد إضافة محتواها إلى الخريطة المعطاة. | |||
==القيم المعادة== | ==القيم المعادة== | ||
يُعاد كائن جديد يحوي جميع عناصر الكائن المعطى (ومن النوع نفسه) بالإضافة إلى العناصر أو الكائنات الممرَّرة. | يُعاد كائن جديد يحوي جميع عناصر الكائن المعطى (ومن النوع نفسه) بالإضافة إلى العناصر أو الكائنات الممرَّرة. | ||
سطر 144: | سطر 160: | ||
[[تصنيف:Kotlin]] | [[تصنيف:Kotlin]] | ||
[[تصنيف:Kotlin Function]] | [[تصنيف:Kotlin Function]] | ||
[[تصنيف:Kotlin Collection]] |
المراجعة الحالية بتاريخ 09:56، 8 سبتمبر 2018
تضيف الدالة plus()
الوسيط المُمرَّر إليها إلى الكائن الذي استدعيت معه.
البنية العامة
إن استدعيت الدالة plus()
مع المصفوفات، فستعيد مصفوفة تضم جميع عناصر المصفوفة التي استدعيت معها إضافةً إلى العنصر المُمرّر إليها:
operator fun <T> Array<T>.plus(element: T): Array<T>
operator fun ByteArray.plus(element: Byte): ByteArray
operator fun ShortArray.plus(element: Short): ShortArray
operator fun IntArray.plus(element: Int): IntArray
operator fun LongArray.plus(element: Long): LongArray
operator fun FloatArray.plus(element: Float): FloatArray
operator fun DoubleArray.plus(element: Double): DoubleArray
operator fun BooleanArray.plus(
element: Boolean
): BooleanArray
وإن استدعيت هذه الدالة مع المصفوفات مع تمرير مجموعة كمعامل، فستعيد مصفوفة تضم جميع عناصر المصفوفة التي استدعيت معها إضافةً إلى عناصر تلك المجموعة المعطاة:
operator fun <T> Array<T>.plus(
elements: Collection<T>
): Array<T>
operator fun ByteArray.plus(
elements: Collection<Byte>
): ByteArray
operator fun ShortArray.plus(
elements: Collection<Short>
): ShortArray
operator fun IntArray.plus(
elements: Collection<Int>
): IntArray
operator fun LongArray.plus(
elements: Collection<Long>
): LongArray
operator fun FloatArray.plus(
elements: Collection<Float>
): FloatArray
operator fun DoubleArray.plus(
elements: Collection<Double>
): DoubleArray
operator fun BooleanArray.plus(
elements: Collection<Boolean>
): BooleanArray
operator fun CharArray.plus(
elements: Collection<Char>
): CharArray
وإن استدعيت هذه الدالة مع المصفوفات مع تمرير مصفوفة كمعامل، فستعيد مصفوفة تضم جميع عناصر المصفوفة التي استدعيت معها إضافةً إلى جميع عناصر المصفوفة المُمرّرة:
operator fun <T> Array<T>.plus(
elements: Array<out T>
): Array<T>
operator fun ByteArray.plus(elements: ByteArray): ByteArray
operator fun ShortArray.plus(
elements: ShortArray
): ShortArray
operator fun IntArray.plus(elements: IntArray): IntArray
operator fun LongArray.plus(elements: LongArray): LongArray
operator fun FloatArray.plus(
elements: FloatArray
): FloatArray
operator fun DoubleArray.plus(
elements: DoubleArray
): DoubleArray
operator fun BooleanArray.plus(
elements: BooleanArray
): BooleanArray
وإن استدعيت هذه الدالة مع المجموعات، فستعيد قائمةً تضم جميع عناصر المجموعة التي استدعيت معها إضافة إلى العنصر المُمرّر:
operator fun <T> Iterable<T>.plus(element: T): List<T>
operator fun <T> Collection<T>.plus(element: T): List<T>
وإن استدعيت هذه الدالة مع المجموعات مع تمرير مصفوفة كمعامل، فستعيد قائمة تضم جميع عناصر المجموعة التي استدعيت معها إضافةً إلى عناصر المصفوفة المُمرّرة:
operator fun <T> Iterable<T>.plus(
elements: Array<out T>
): List<T>
operator fun <T> Collection<T>.plus(
elements: Array<out T>
): List<T>
وإن استدعيت هذه الدالة مع المجموعات مع تمرير مجموعة كمعامل، فستعيد قائمة تضم جميع عناصر المجموعة التي استدعيت معها إضافةً إلى عناصر المجموعة المُمرّرة:
operator fun <T> Iterable<T>.plus(
elements: Iterable<T>
): List<T>
operator fun <T> Collection<T>.plus(
elements: Iterable<T>
): List<T>
وإن استدعيت هذه الدالة مع المجموعات مع تمرير سلسلة كمعامل، فستعيد قائمة تضم جميع عناصر المجموعة التي استدعيت معها إضافةً إلى عناصر السلسلة المُمرّرة:
operator fun <T> Iterable<T>.plus(
elements: Sequence<T>
): List<T>
operator fun <T> Collection<T>.plus(
elements: Sequence<T>
): List<T>
وإن استدعيت هذه الدالة مع مجموعة من النوع Set
، فستعيد مجموعة من ذات النوع تضم جميع عناصر المجموعة التي استدعيت معها إضافةً إلى العنصر المُمرّر إن لم يكن موجودًا مسبقًا، وستحافظ المجموعة المعادة على ترتيب التكرار للمجموعة الأصلية:
operator fun <T> Set<T>.plus(element: T): Set<T>
وإن استدعيت هذه الدالة مع مجموعة من النوع Set
مع تمرير مصفوفة كوسيط، فستعيد مجموعة من النوع Set
تضم جميع عناصر المجموعة التي استدعيت معها إضافةً إلى عناصر المصفوفة المُمرّرة الغير موجودة مسبقًا؛ تحافظ المجموعة المعادة على ترتيب التكرار للمجموعة الأصلية:
operator fun <T> Set<T>.plus(elements: Array<out T>): Set<T>
وإن استدعيت هذه الدالة مع مجموعة من النوع Set
مع تمرير مجموعة كوسيط، فستعيد مجموعة من النوع Set
تضم جميع عناصر المجموعة التي استدعيت معها إضافةً إلى عناصر المجموعة المُمرّرة الغير موجودة مسبقًا؛ تحافظ المجموعة المعادة على ترتيب التكرار للمجموعة الأصلية:
operator fun <T> Set<T>.plus(elements: Iterable<T>): Set<T>
وإن استدعيت هذه الدالة مع مجموعة من النوع Set
مع تمرير سلسلة كوسيط، فستعيد مجموعةً من النوع Set
تضم جميع عناصر المجموعة التي استدعيت معها إضافةً إلى عناصر السلسلة المُمرّرة الغير موجودة مسبقًا؛ تحافظ المجموعة المعادة على ترتيب التكرار للمجموعة الأصلية:
operator fun <T> Set<T>.plus(elements: Iterable<T>): Set<T>
وإن استدعيت هذه الدالة مع خريطة، فستعيد خريطة جديدة للقراءة فقط (read-only) تحوي جميع عناصر تلك الخريطة مع استبدال أو إضافة الزوج pair
المعطى إليها؛ تحافظ الخريطة المعادة على ترتيب التكرار للخريطة الأصلية، وسيضاف الزوج pair
في النهاية إن كان يملك مفتاحًا فريدًا:
operator fun <K, V> Map<out K, V>.plus(
pair: Pair<K, V>
): Map<K, V>
وإن استدعيت هذه الدالة مع خريطة مع تمرير مجموعة كوسيط، فستعيد خريطة جديدة للقراءة فقط (read-only) تحوي جميع عناصر تلك الخريطة مع استبدال أو إضافة الأزواج pairs
المعطاة من تلك المجموعة إليها؛ تحافظ الخريطة المعادة على ترتيب التكرار للخريطة الأصلية، وستضاف الأزواج pairs
ذات المفاتيح الفريدة في النهاية وبنفس الترتيب الذي أعطيت به:
operator fun <K, V> Map<out K, V>.plus(
pairs: Iterable<Pair<K, V>>
): Map<K, V>
وإن استدعيت هذه الدالة مع خريطة مع تمرير مصفوفة كوسيط، فستعيد خريطة جديدة للقراءة فقط (read-only) تحوي جميع عناصر تلك الخريطة مع استبدال أو إضافة الأزواج pairs
المعطاة من تلك المصفوفة إليها؛ تحافظ الخريطة المعادة على ترتيب التكرار للخريطة الأصلية، وستضاف الأزواج pairs
ذات المفاتيح الفريدة في النهاية وبنفس الترتيب الذي أعطيت به:
operator fun <K, V> Map<out K, V>.plus(
pairs: Array<out Pair<K, V>>
): Map<K, V>
وإن استدعيت هذه الدالة مع خريطة مع تمرير سلسلة كوسيط، فستعيد خريطة جديدة للقراءة فقط (read-only) تحوي جميع عناصر تلك الخريطة مع استبدال أو إضافة الأزواج pairs
المعطاة من تلك السلسلة إليها؛ تحافظ الخريطة المعادة على ترتيب التكرار للخريطة الأصلية، وستضاف الأزواج pairs
ذات المفاتيح الفريدة في النهاية وبنفس الترتيب الذي أعطيت به:
operator fun <K, V> Map<out K, V>.plus(
pairs: Sequence<Pair<K, V>>
): Map<K, V>
وإن استدعيت هذه الدالة مع خريطة مع تمرير خريطة أخرى كوسيط، فستعيد خريطة جديدة للقراءة فقط (read-only) تحوي جميع عناصر تلك الخريطة مع استبدال أو إضافة الأزواج pairs
من تلك الخريطة المعطاة إليها؛ وستضاف أزواج الخريطة map
المعطاة ذات المفاتيح الفريدة في النهاية وبنفس الترتيب الذي أعطيت به:
operator fun <K, V> Map<out K, V>.plus(
map: Map<out K, V>
): Map<K, V>
وجود الكلمة المفتاحية inline
يدل على أنَّ هذه الدالة مباشرة (للمزيد من التفاصيل، راجع صفحة الدوال المباشرة (inline functions)).
المعاملات
element
العنصر المراد إضافته.
elements
العناصر المراد إضافتها.
pair
الزوج المراد إضافته إلى الخريطة المعطاة.
pairs
الأزواج المراد إضافتها إلى الخريطة المعطاة.
map
الخريطة التي يراد إضافة محتواها إلى الخريطة المعطاة.
القيم المعادة
يُعاد كائن جديد يحوي جميع عناصر الكائن المعطى (ومن النوع نفسه) بالإضافة إلى العناصر أو الكائنات الممرَّرة.
أمثلة
استعمال الدالة ()plus
لإضافة عنصر واحد إلى قائمة:
fun main(args: Array<String>) {
val iterable = listOf(1, 2, 3, 4, 5)
println(iterable.plus(7)) // [1, 2, 3, 4, 5, 7]
}
استعمال الدالة ()plus
لإضافة جميع عناصر مصفوفة إلى قائمة:
fun main(args: Array<String>) {
val iterable = listOf(1, 2, 3, 4, 5)
val array = arrayOf(13, 25, 6)
println(iterable.plus(array)) // [1, 2, 3, 4, 5, 13, 25, 6]
}
انظر أيضًا
- الدالة
plusElement()
: تضيف العنصر المُمرّر إليها إلى المصفوفة أو المجموعة التي استُدعيت معها. - الدالة
fill()
: تبدِّل قيمة جديدة معطاة مكان عناصر محدَّدة في المصفوفة أو القائمة التي تستدعى معها. - الدالة
joinTo()
: تضيف بادئة ولاحقة إلى جميع عناصر المصفوفة أو المجموعة التي استُدعيت معها (أو جزءٍ منها) وتفصلها بفاصلة معينة ثمَّ تضيفها إلى سلسة نصية موجودة مسبقًا.