الفرق بين المراجعتين ل"Kotlin/collections/sortBy"

من موسوعة حسوب
اذهب إلى التنقل اذهب إلى البحث
(أنشأ الصفحة ب'<noinclude>{{DISPLAYTITLE: الدالة <code>sortBy()‎</code> في لغة Kotlin}}</noinclude> تقوم الدالة<code>sortBy()‎</code> بترتيب Kotlin/Ar...')
 
سطر 1: سطر 1:
 
<noinclude>{{DISPLAYTITLE: الدالة <code>sortBy()‎</code> في لغة Kotlin}}</noinclude>
 
<noinclude>{{DISPLAYTITLE: الدالة <code>sortBy()‎</code> في لغة Kotlin}}</noinclude>
تقوم الدالة<code>sortBy()‎</code> بترتيب  [[Kotlin/Array|المصفوفة]] أو [[kotlin/MutableList|اللائحة المتغيرة]] (<code>MutableList</code>) التي استُدعيت عبرها.  
+
تقوم الدالة<code>sortBy()‎</code> بترتيب  [[Kotlin/Array|المصفوفة]] أو [[kotlin/MutableList|اللائحة المتغيرة]] (<code>MutableList</code>) التي استُدعيت عبرها وفقًا للقيم التي تعيدها الدالة المُمرّرة <code>selector</code>.  
  
 
==البنية العامة==
 
==البنية العامة==
في حال استدعاء الدالة  <code>sortBy()‎</code> عبر  [[Kotlin/Array|مصفوفة]] فستقوم بترتيبها: <nowiki/><nowiki/><syntaxhighlight lang="kotlin">
+
يمكن استدعاء الدالة  <code>sortBy()‎</code> عبر  [[Kotlin/Array|المصفوفات]]: <nowiki/><nowiki/><syntaxhighlight lang="kotlin">
fun IntArray.sort()
+
inline fun <T, R : Comparable<R>> Array<out T>.sortBy(
fun LongArray.sort()
+
    crossinline selector: (T) -> R?)
fun ByteArray.sort()
+
</syntaxhighlight><nowiki/><nowiki/>يمكن استدعاء الدالة  <code>sortBy()‎</code> عبر  كائن من النوع <code>[[kotlin/MutableList|MutableList]]</code>:<nowiki/><nowiki/><syntaxhighlight lang="kotlin">
fun ShortArray.sort()
+
inline fun <T, R : Comparable<R>> MutableList<T>.sortBy(
fun DoubleArray.sort()
+
     crossinline selector: (T) -> R?)
fun FloatArray.sort()
+
</syntaxhighlight>يُلاحَظ وجود الكلمة المفتاحية <code>inline</code> للدلالة على أن هذه الدالة مباشرة، وللمزيد من التفاصيل راجع <nowiki/>[[Kotlin/inline functions|توثيق الدوال المباشرة (inline functions)]].  
fun CharArray.sort()
 
inline fun <T : Comparable<T>> Array<out T>.sort() (source)
 
 
 
</syntaxhighlight>في حال استدعاء الدالة  <code>slice()‎</code> عبر  [[Kotlin/Array|مصفوفة]] مع تمرير معاملين عددين فستقوم بترتيب المجال المحدد بذلك المعاملين داخل [[Kotlin/Array|المصفوفة]]: <nowiki/><nowiki/><syntaxhighlight lang="kotlin">
 
fun <T> Array<out T>.sort(
 
    fromIndex: Int = 0,
 
    toIndex: Int = size)
 
fun ByteArray.sort(fromIndex: Int = 0, toIndex: Int = size)
 
fun ShortArray.sort(fromIndex: Int = 0, toIndex: Int = size)
 
fun IntArray.sort(fromIndex: Int = 0, toIndex: Int = size)
 
fun LongArray.sort(fromIndex: Int = 0, toIndex: Int = size)
 
fun FloatArray.sort(fromIndex: Int = 0, toIndex: Int = size)
 
fun DoubleArray.sort(fromIndex: Int = 0, toIndex: Int = size)
 
fun CharArray.sort(fromIndex: Int = 0, toIndex: Int = size)
 
 
 
</syntaxhighlight>'''بيئة التشغيل: JVM'''
 
 
 
في حال استدعاء الدالة  <code>slice()‎</code> عبر  كائن من النوع <code>[[kotlin/MutableList|MutableList]]</code> فستقوم بترتيبه:<syntaxhighlight lang="kotlin">
 
fun <T : Comparable<T>> MutableList<T>.sort()
 
 
 
</syntaxhighlight>في حال استدعاء الدالة  <code>slice()‎</code> عبر  [[Kotlin/Array|مصفوفة]] مع تمرير مًقارن <code>comparison</code> كمعامل فستقوم بترتيب تلك [[Kotlin/Array|المصفوفة]] بحسب الترتيب الذي يحدده المقارن <code>comparison</code>: <syntaxhighlight lang="kotlin">
 
inline fun <T> Array<out T>.sort(
 
     noinline comparison: (a: T, b: T) -> Int)
 
inline fun ByteArray.sort(
 
    noinline comparison: (a: Byte, b: Byte) -> Int)
 
inline fun ShortArray.sort(
 
    noinline comparison: (a: Short, b: Short) -> Int)
 
inline fun IntArray.sort(
 
    noinline comparison: (a: Int, b: Int) -> Int)
 
inline fun LongArray.sort(
 
    noinline comparison: (a: Long, b: Long) -> Int)
 
inline fun FloatArray.sort(
 
    noinline comparison: (a: Float, b: Float) -> Int)
 
inline fun DoubleArray.sort(
 
    noinline comparison: (a: Double, b: Double) -> Int)
 
inline fun CharArray.sort(
 
    noinline comparison: (a: Char, b: Char) -> Int)
 
 
 
</syntaxhighlight>يُلاحَظ وجود الكلمة المفتاحية <code>inline</code> للدلالة على أن هذه الدالة مباشرة، وللمزيد من التفاصيل راجع <nowiki/>[[Kotlin/inline functions|توثيق الدوال المباشرة (inline functions)]].
 
 
 
 
==أمثلة==
 
==أمثلة==
 
===استخدام الدالة <code>()sortBy</code> مع المصفوفات===
 
===استخدام الدالة <code>()sortBy</code> مع المصفوفات===
تعرف الشيفرة الآتية  <nowiki/>[[Kotlin/Array|مصفوفة]]<nowiki/>باسم <code>array</code> مكونة من ستة عناصر باستخدام الدالة <code>()arrayOf‎</code>، ثم تستخدم الدالة<code>()sort</code>  على <code>array</code> لترتيبه، ثم تطبع الناتج:<syntaxhighlight lang="kotlin">
+
تعرف الشيفرة الآتية  <nowiki/>[[Kotlin/Array|مصفوفة]] <nowiki/>باسم <code>array</code> مكونة من ستة عناصر باستخدام الدالة <code>()arrayOf‎</code>، ثم تستخدم الدالة<code>()sortBy</code>  على <code>array</code> لترتيبه مع تمرير دالة كوسيط، ثم تطبع الناتج:<syntaxhighlight lang="kotlin">
 
import java.util.Arrays
 
import java.util.Arrays
  
 
fun main(args: Array<String>) {
 
fun main(args: Array<String>) {
val array = arrayOf(1, 9, 3, 7, 5, 6)
+
val array = arrayOf(1, -9, -3, 7, 5, 6)
 
+
   
array.sort()
+
array.sortBy({it*it})
 
      
 
      
print (Arrays.toString(array)) // [1, 3, 5, 6, 7, 9]
+
print (Arrays.toString(array)) // [1, -3, 5, 6, 7, -9]
 
}
 
}
 
</syntaxhighlight>
 
</syntaxhighlight>
 
===أنظر أيضًا===
 
===أنظر أيضًا===
*<code>[[Kotlin/collections/sliceArray|sliceArray()]]</code>‎ : تعيد [[Kotlin/List|لائحة]] أو [[Kotlin/Array|مصفوفة]] تحتوي عناصر [[Kotlin/Array|المصفوفة]] التي استُدعيت عبرها والموجودة عند الفهارس التي يحددها الوسيط الممرّر <code>indices</code>. 
+
*<code>[[Kotlin/collections/sort|sort()]]</code>‎ : تقوم بترتيب  [[Kotlin/Array|المصفوفة]] أو [[Kotlin/MutableList|اللائحة المتغيرة]] (<code>MutableList</code>) التي استُدعيت عبرها
 
==مصادر==
 
==مصادر==
*[https://kotlinlang.org/api/latest/jvm/stdlib/kotlin.collections/sort.html الدالة  sortBy()‎ في التوثيق الرسميّ للمكتبة القياسيّة في لغة Kotlin.]
+
*[https://kotlinlang.org/api/latest/jvm/stdlib/kotlin.collections/sort-by.html الدالة  sortBy()‎ في التوثيق الرسميّ للمكتبة القياسيّة في لغة Kotlin.]
 
[[تصنيف:Kotlin]]
 
[[تصنيف:Kotlin]]
 
[[تصنيف:Kotlin Functions]]
 
[[تصنيف:Kotlin Functions]]

مراجعة 17:44، 6 يونيو 2018

تقوم الدالةsortBy()‎ بترتيب المصفوفة أو اللائحة المتغيرة (MutableList) التي استُدعيت عبرها وفقًا للقيم التي تعيدها الدالة المُمرّرة selector.

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

يمكن استدعاء الدالة  sortBy()‎ عبر المصفوفات:

inline fun <T, R : Comparable<R>> Array<out T>.sortBy(
    crossinline selector: (T) -> R?)

يمكن استدعاء الدالة  sortBy()‎ عبر كائن من النوع MutableList:

inline fun <T, R : Comparable<R>> MutableList<T>.sortBy(
    crossinline selector: (T) -> R?)

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

أمثلة

استخدام الدالة ()sortBy مع المصفوفات

تعرف الشيفرة الآتية  مصفوفة باسم array مكونة من ستة عناصر باستخدام الدالة ()arrayOf‎، ثم تستخدم الدالة()sortBy  على array لترتيبه مع تمرير دالة كوسيط، ثم تطبع الناتج:

import java.util.Arrays

fun main(args: Array<String>) {
val array = arrayOf(1, -9, -3, 7, 5, 6)
    
array.sortBy({it*it})
    
print (Arrays.toString(array)) // [1, -3, 5, 6, 7, -9]
}

أنظر أيضًا

مصادر