الفرق بين المراجعتين لصفحة: «Kotlin/collections/contentDeepEquals»
لا ملخص تعديل |
جميل-بيلوني (نقاش | مساهمات) طلا ملخص تعديل |
||
(8 مراجعات متوسطة بواسطة 3 مستخدمين غير معروضة) | |||
سطر 1: | سطر 1: | ||
<noinclude>{{DISPLAYTITLE: الدالة <code>contentDeepEquals()</code> في | <noinclude>{{DISPLAYTITLE: الدالة <code>contentDeepEquals()</code> في Kotlin}}</noinclude> | ||
تتحقق الدالة <code>contentDeepEquals()</code> من تساوي مصفوفتين بالعُمق، أي أنهما تحتويان على نفس العناصر وبنفس الترتيب. | |||
إن | إن تقابل عنصران وكان كلاهما مصفوفتين متشعبتين، فسيُتحقق من تساويهما بالعمق أيضًا بالطريقة ذاتها. وإن كانت إحدى المصفوفتين تحتوي على مرجع لها (تحتوي على نفسها) في أيّ مستوى من مستويات التشعب، فسيكون سلوك الدالة غير محدَّد. | ||
==البنية العامة== | ==البنية العامة== | ||
سطر 11: | سطر 11: | ||
</syntaxhighlight> | </syntaxhighlight> | ||
'''الإصدار المطلوب: Kotlin 1.1''' | |||
وجود الكلمة المفتاحية <code>inline</code> يدل على أنَّ هذه الدالة مباشرة (للمزيد من التفاصيل راجع <nowiki/>[[Kotlin/inline functions|توثيق الدوال المباشرة (inline functions)]]). | |||
== المعاملات == | |||
=== <code>other</code> === | |||
المصفوفة الأخرى المراد التحقق من تساويها بالعمق مع المصفوفة المعطاة. | |||
==القيم المعادة== | ==القيم المعادة== | ||
<code>true</code> إن كانت المصفوفتان المحددتان متساويتان | تُعاد القيمة المنطقية <code>true</code> إن كانت المصفوفتان المحددتان متساويتان بالعُمق، أي أنَّهما تحتويان على نفس العناصر وبنفس الترتيب، أو القيمة المنطقيَّة <code>false</code> خلاف ذلك. | ||
==أمثلة== | ==أمثلة== | ||
تعرِّف الشيفرة الآتية مصفوفتين باسم <code>array</code> و <code>array2</code> لهما نفس العناصر وبنفس الترتيب باستخدام الدالة <code>()arrayOf</code>، ثمَّ تستخدم الدالة <code>()contentDeepEquals</code> للتحقق من أنّ لهما العمق ذاته:<syntaxhighlight lang="kotlin"> | |||
fun main(args: Array<String>) { | fun main(args: Array<String>) { | ||
val | val array1 = arrayOf(1, 2, 3, 4) | ||
val array2 = arrayOf(1,2,3,6) | val array2 = arrayOf(1, 2, 3, 4) | ||
val array3 = arrayOf(1, 2, 3, 6) | |||
println( | println(array1.contentDeepEquals(array2)) // true | ||
println(array1.contentDeepEquals(array3)) // false | |||
} | } | ||
</syntaxhighlight> | </syntaxhighlight> | ||
==انظر أيضًا== | ==انظر أيضًا== | ||
*<code>[[Kotlin/collections/ | *الدالة <code>[[Kotlin/collections/contentEquals|contentEquals()]]</code>: تتحقَّق من تساوي <nowiki/>[[Kotlin/Array|مصفوفتين]] بنيويًا (''structurally'' equal)، أي إن كان لهما نفس العناصر وبنفس العدد والترتيب. | ||
*الدالة <code>[[Kotlin/collections/contentDeepToString|contentDeepToString()]]</code>: تعيد سلسلة نصية تمثِّل محتوى <nowiki/>[[Kotlin/Array|المصفوفة]] التي استُدعيت معها كما لو كانت قائمة. | |||
* الدالة <code>[[Kotlin/collections/contentDeepHashCode|contentDeepHashCode()]]</code>: تعيد شيفرة hash لمحتوى <nowiki/>[[Kotlin/Array|المصفوفة]] التي استدعيت معها كما لو كانت قائمة. | |||
*الدالة <code>[[Kotlin/collections/contains|contains()]]</code>: تتحقق إن كانت <nowiki/>[[Kotlin/Array|المصفوفة]] أو <nowiki/>[[Kotlin/collections|المجموعة]] التي استُدعيت معها تحتوي على العنصر الممرّر إليها، أو إن كانت الخريطة التي استدعيت معها تحتوي على ذلك العنصر كمفتاح (key). | |||
==مصادر== | ==مصادر== | ||
*[https://kotlinlang.org/api/latest/jvm/stdlib/kotlin.collections/ | *[https://kotlinlang.org/api/latest/jvm/stdlib/kotlin.collections/content-deep-equals.html صفحة الدالة contentDeepEquals() في التوثيق الرسميّ للمكتبة القياسيّة في لغة Kotlin.] | ||
[[تصنيف:Kotlin]] | [[تصنيف:Kotlin]] | ||
[[تصنيف:Kotlin | [[تصنيف:Kotlin Function]] | ||
[[تصنيف:Kotlin Collection]] |
المراجعة الحالية بتاريخ 07:27، 8 سبتمبر 2018
تتحقق الدالة contentDeepEquals()
من تساوي مصفوفتين بالعُمق، أي أنهما تحتويان على نفس العناصر وبنفس الترتيب.
إن تقابل عنصران وكان كلاهما مصفوفتين متشعبتين، فسيُتحقق من تساويهما بالعمق أيضًا بالطريقة ذاتها. وإن كانت إحدى المصفوفتين تحتوي على مرجع لها (تحتوي على نفسها) في أيّ مستوى من مستويات التشعب، فسيكون سلوك الدالة غير محدَّد.
البنية العامة
inline infix fun <T> Array<out T>.contentDeepEquals(
other: Array<out T>
): Boolean
الإصدار المطلوب: Kotlin 1.1
وجود الكلمة المفتاحية inline
يدل على أنَّ هذه الدالة مباشرة (للمزيد من التفاصيل راجع توثيق الدوال المباشرة (inline functions)).
المعاملات
other
المصفوفة الأخرى المراد التحقق من تساويها بالعمق مع المصفوفة المعطاة.
القيم المعادة
تُعاد القيمة المنطقية true
إن كانت المصفوفتان المحددتان متساويتان بالعُمق، أي أنَّهما تحتويان على نفس العناصر وبنفس الترتيب، أو القيمة المنطقيَّة false
خلاف ذلك.
أمثلة
تعرِّف الشيفرة الآتية مصفوفتين باسم array
و array2
لهما نفس العناصر وبنفس الترتيب باستخدام الدالة ()arrayOf
، ثمَّ تستخدم الدالة ()contentDeepEquals
للتحقق من أنّ لهما العمق ذاته:
fun main(args: Array<String>) {
val array1 = arrayOf(1, 2, 3, 4)
val array2 = arrayOf(1, 2, 3, 4)
val array3 = arrayOf(1, 2, 3, 6)
println(array1.contentDeepEquals(array2)) // true
println(array1.contentDeepEquals(array3)) // false
}
انظر أيضًا
- الدالة
contentEquals()
: تتحقَّق من تساوي مصفوفتين بنيويًا (structurally equal)، أي إن كان لهما نفس العناصر وبنفس العدد والترتيب. - الدالة
contentDeepToString()
: تعيد سلسلة نصية تمثِّل محتوى المصفوفة التي استُدعيت معها كما لو كانت قائمة. - الدالة
contentDeepHashCode()
: تعيد شيفرة hash لمحتوى المصفوفة التي استدعيت معها كما لو كانت قائمة. - الدالة
contains()
: تتحقق إن كانت المصفوفة أو المجموعة التي استُدعيت معها تحتوي على العنصر الممرّر إليها، أو إن كانت الخريطة التي استدعيت معها تحتوي على ذلك العنصر كمفتاح (key).