التابع Any.hashCode() في لغة Kotlin
يعيد التابع hashCode()
قيمة الشيفرة hash code الخاصّة بالكائن الذي استُدعي عبره، ويحقِّق التابع hashCode()
دائمًا الشرطين الآتيين:
- سيعيد نفس العدد الصحيح دائمًا في كل مرة يُستدعى على كائنٍ مُعيَّن شريطة عدم تغيُّر أيّ معلومة يستخدمها التابع
equals()
لأجل المقارنة مع الكائن. - إذا تساوى كائنان بحسب التابع
equals()
، فسينتج نفس العدد الصحيح (المُعبِّر عن الشيفرة hash code) عند استدعاء التابعhashCode()
على أيٍّ منهما.
البنية العامة
open fun hashCode(): Int
يُلاحظ وجود الكلمة المفتاحيّة open هنا وذلك للسماح بإعادة تعريف (override) هذا التابع في الأصناف الفرعيّة (subclasses) للصنف Any (راجع الأصناف والوراثة لمزيد من التفاصيل).
القيم المعادة
قيمةٌ صحيحةٌ من النوع Int
تمثِّل الشيفرة hash code للكائن.
أمثلة
استخدام الدالة hashCode()
تعرِّف الشيفرة الآتية متغيِّرًا من نوع السلاسل النصيّة (String
) ثم تستدعي التابع hashCode()
للحصول على الشيفرة hash code الخاصّة بتلك السلسة النصيّة وطباعتها، ثم تُعرّف متغيّرًا x
وتستدعي التابع كذلك للحصول على الشيفرة hash code له وطباعتها، كما يلي:
fun main(args: Array<String>) {
var a: String = "hsoub"
var hash_a = a.hashCode()
println(" $hash_a") // 99582545
var x = 54
var hash_x = x.hashCode()
println(" $hash_x") //54
}
انظر أيضًا
- التابع
equals()
: يبيّن فيما إذا كان هناك كائنٌ (object) آخر مساوٍ للكائن الحاليّ.