الدالة component1()‎ في Kotlin

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

تعيد الدالة component1()‎ العنصر الأول من المصفوفة أو المفتاح (key) لأول زوج (مفتاح/قيمة) في الخريطة (map) التي استدعيت معها. تسمح هذه الدالة باستخدام التصريحات التفكيكية (destructuring declarations) عند العمل على الخرائط. 

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

يمكن استدعاء الدالة component1()‎ مع المصفوفات والقوائم (list):

inline operator fun <T> Array<out T>.component1(): T 
inline operator fun ByteArray.component1(): Byte 
inline operator fun ShortArray.component1(): Short
inline operator fun IntArray.component1(): Int 
inline operator fun LongArray.component1(): Long 
inline operator fun FloatArray.component1(): Float 
inline operator fun DoubleArray.component1(): Double 
inline operator fun BooleanArray.component1(): Boolean 
inline operator fun CharArray.component1(): Char 
inline operator fun <T> List<T>.component1(): T

ويمكن استدعاؤها مع الخرائط (maps):

inline operator fun <K, V> Entry<K, V>.component1(): K

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

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

يُعاد العنصر الأول من المصفوفة أو قيمة المفتاح (key) لأول زوج (مفتاح/قيمة) في الخريطة (map) التي استدعيت معها.

أمثلة

استخدام الدالة ()component1 مع القوائم

تعرِّف الشيفرة الآتية قائمة باسم list مكونة من خمسة حروف باستخدام الدالة ()listOf ثم تستخدم الدالة ()component1 لجلب العنصر الأول من القائمة list وتطبع الناتج:

fun main(args: Array<String>) {
    val list = listOf('a', 'b', 'c', 'd', 'e')
    println(list.component1()) // a
}

استخدام الدالة ()component1 مع الخرائط

تعرف الشيفرة الآتية خريطةً باسم map مكونة من زوجين اثنين (مفتاح/قيمة) باستخدام الدالة ()hashMapOf، ثم تستخدم الدالة ()component1 لجلب قيمة المفتاح لكل زوج في الخريطة باستعمال الحلقة for وتطبع الناتج:

fun main(args: Array<String>) {
    val map = hashMapOf("foo" to 1, "bar" to 2)
    for (x in map) {
        println(x.component1()) // bar foo
    }
}

انظر أيضًا

  • الدالة associate()‎: تعيد خريطةً (map) تحوي أزواجًا من "مفتاح/قيمة" ناتجة عن تمرير عناصر مصفوفة أو مجموعة (Collection) إلى الدالة ()transform.
  • الدالة asList()‎: تعيد قائمة تُغلّف المصفوفة الأصليَّة.
  • الدالة contains()‎: تتحقق إن كانت المصفوفة أو المجموعة التي استُدعيت معها تحتوي على العنصر الممرّر إليها، أو إن كانت الخريطة التي استدعيت معها تحتوي على ذلك العنصر كمفتاح (key).
  • الخاصيّة Array.size: تعبِّر عن عدد العناصر الموجودة في المصفوفة.

مصادر