الدالة contentDeepEquals()
في لغة Kotlin
تتحقق الدالة contentDeepEquals()
من تساوي مصفوفتين بالعُمق، أي أنهما تحتويان على نفس العناصر وبنفس الترتيب.
إن تقابل عنصران وكان كلاهما مصفوفتين متشعبتين، فسيُتحقق من تساويهما بالعمق أيضًا بالطريقة ذاتها. وإن كانت إحدى المصفوفتين تحتوي على مرجع لها (تحتوي على نفسها) في أيّ مستوى من مستويات التشعب، فسيكون سلوك الدالة غير محدَّد.
البنية العامة
inline infix fun <T> Array<out T>.contentDeepEquals(
other: Array<out T>
): Boolean
الإصدار المطلوب: Kotlin 1.1
وجود الكلمة المفتاحية inline
يدل على أنَّ هذه الدالة مباشرة (للمزيد من التفاصيل راجع توثيق الدوال المباشرة (inline functions)).
القيم المعادة
القيمة المنطقية true
إن كانت المصفوفتان المحددتان متساويتان بالعُمق، أي أنَّهما تحتويان على نفس العناصر وبنفس الترتيب، أو القيمة المنطقيَّة false
خلاف ذلك.
أمثلة
استخدام الدالة ()contentDeepEquals
مع مصفوفتين متساويتين
تعرِّف الشيفرة الآتية مصفوفتين باسم array
و array2
لهما نفس العناصر وبنفس الترتيب باستخدام الدالة ()arrayOf
، ثمَّ تستخدم الدالة ()contentDeepEquals
للتحقق من أنّ لهما العمق ذاته:
fun main(args: Array<String>) {
val array = arrayOf(1,2,3,4)
val array2 = arrayOf(1,2,3,4)
println(array.contentDeepEquals(array2)) // true
}
استخدام الدالة ()contentDeepEquals
مع مصفوفتين غير متساويتين
تعرِّف الشيفرة الآتية مصفوفتين باسم array
و array2
لهما نفس عدد العناصر ولكن تختلفان في أحدها باستخدام الدالة ()arrayOf
، ثمَّ تستخدم الدالة ()contentDeepEquals
للتحقق من أنّ لهما العمق ذاته:
fun main(args: Array<String>) {
val array = arrayOf(1,2,3,4)
val array2 = arrayOf(1,2,3,6)
println(array.contentDeepEquals(array2)) // false
}
انظر أيضًا
- الدالة
contentEquals()
: تتحقَّق إن كانت مصفوفتان متساويتان بنيويًا (structurally equal)، أي أنَّهما تحتويان على نفس عدد العناصر ونفس العناصر بنفس الترتيب. - الدالة
contains()
: تتحقق إن كانت المصفوفة أو المجموعة التي استُدعيت معها تحتوي على العنصر الممرّر إليها، أو إن كانت الخريطة التي استدعيت معها تحتوي على ذلك العنصر كمفتاح (key). - الدالة
contentDeepToString()
: تعيد تمثيلًا نصيًا استنادًا إلى محتوى المصفوفة التي استُدعيت معها كما لو كانت قائمة.