الدالة ‎‎unsafeCast()‎ للتحويل غير الآمن بين الأنواع في Kotlin

من موسوعة حسوب
(بالتحويل من Kotlin/js/unsafeCast)

يحوِّل المعامل as الكائن الذي استُدعي عبره إلى نوعٍ  آخر (T) بشكلٍ غير آمن (unsafe) أي بدون التحقُّق من الأنواع، فإن  كان التحويل غير جائزٍ، فسيُعلِم المُترجم بوجود خطأٍ، ويعبِّر المعامل as عن استدعاء الدالة unsafeCast()‎ التي تجري عملية التحويل الفعليّ.

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

inline fun <T> Any?.unsafeCast(): T

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

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

تعاد قيمة الكائن (object) بعد تحويله إلى النوع الآخر المُحدَّد (T).

أمثلة

استخدام المعامل as للتحويل غير الآمن (unsafe) لسلسلة نصية (string):

تعرّف الشيفرة الآتية متغيرًا باسم x من النوع Int، ثم تستخدم معامل التحويل غير الآمن as لتحويل هذا المتغيّر إلى سلسلةٍ نصيّة (string)، ولمّا كان ذلك غير جائزٍ فسيُعلِم المُترجم بوجود خطأ:

fun main(args: Array<String>) {
    val x:Int = 5
    val y: String? = x as String?  // error
}

ويُلاحَظ وجود المعامل ? عند النوع String للدلالة على أنّه nullable.

استخدام المعامل as?‎ للتحويل الآمن (safe) لسلسلة نصية (string):

تعرّف الشيفرة الآتية متغيرًا باسم x من النوع Int، ثم تستخدم معامل التحويل الآمن as?‎ لتحويل هذا المتغيّر إلى سلسلة نصيّة (string)، ولمّا كان ذلك غير جائزٍ فستُعيد القيمة null لذلك المتغير:

fun main(args: Array<String>) {
   val x:Int = 5
   val y: String? = x as? String?    
   print(y)   // null
}

انظر أيضًا

مصادر