الفرق بين المراجعتين لصفحة: «Kotlin/let»
أنشأ الصفحة ب'<noinclude>{{DISPLAYTITLE: الدالة let() في لغة Kotlin}}</noinclude> تستدعي الدالة let() بنية (block) الدالة المُحدَّدة...' |
لا ملخص تعديل |
||
سطر 1: | سطر 1: | ||
<noinclude>{{DISPLAYTITLE: الدالة let() في لغة Kotlin}}</noinclude> | <noinclude>{{DISPLAYTITLE: الدالة let() في لغة Kotlin}}</noinclude> | ||
تستدعي الدالة let() بنية (block) الدالة المُحدَّدة وذلك بجعل قيمة this كوسيط (argument) لها وتعيد ناتج التنفيذ. | تستدعي الدالة <code>let()</code> بنية (block) الدالة المُحدَّدة وذلك بجعل قيمة <code>this</code> كوسيط (argument) لها وتعيد ناتج التنفيذ. | ||
عادة ما تُُستخدم let لمنع الوصول إلى المتغيرات في مجال الأسماء (namespace) إذ إنّ كل المتغيرات المعرَّفة داخلها لن تكون متاحةً خارج تلك البنية (block). | عادة ما تُُستخدم <code>let()</code>لمنع الوصول إلى المتغيرات في مجال الأسماء (namespace) إذ إنّ كل المتغيرات المعرَّفة داخلها لن تكون متاحةً خارج تلك البنية (block). | ||
== البنية العامة == | == البنية العامة == | ||
<syntaxhighlight lang="kotlin"> | |||
inline fun <T, R> T.let(block: (T) -> R): R | inline fun <T, R> T.let(block: (T) -> R): R | ||
</syntaxhighlight>يُلاحَظ وجود الكلمة المفتاحية <code>inline</code> للدلالة على أن هذه الدالة مباشرة، وللمزيد من التفاصيل راجع [[Kotlin/inline functions|توثيق الدوال المباشرة (inline functions)]]. | |||
يُلاحَظ وجود الكلمة المفتاحية inline للدلالة على أن هذه الدالة مباشرة، وللمزيد من التفاصيل راجع [[Kotlin/inline functions|توثيق الدوال المباشرة (inline functions)]]. | |||
== القيم المعادة == | == القيم المعادة == | ||
تعيد ناتج تنفيذ بنية (block) الدالة المُحدَّدة | تعيد ناتج تنفيذ بنية (block) الدالة المُحدَّدة. | ||
== أمثلة == | == أمثلة == | ||
=== استخدام | === استخدام الدالة<code>let()</code> مع الكائنات (objects) === | ||
تستدعي الشيفرة الآتية الدالة let() عبر الكائن person المُنشَأ من الصنف Person والذي يحتوي على بيانات أوليّة لكلٍ من خاصيتيّ الاسم (name) والعمر (age) مما سيؤدي لتعديلهما بحسب القيم المذكورة في بنية الدالة عبر استدعائهما من الاسم الضمني (implicit name) | تستدعي الشيفرة الآتية الدالة <code>let()</code> عبر الكائن <code>person</code> المُنشَأ من الصنف <code>Person</code> والذي يحتوي على بيانات أوليّة لكلٍ من خاصيتيّ الاسم (<code>name</code>) والعمر (<code>age</code>) مما سيؤدي لتعديلهما بحسب القيم المذكورة في بنية الدالة عبر استدعائهما من الاسم الضمني (implicit name) <code>[[Kotlin/lambdas#it: .D8.A7.D9.84.D8.A7.D8.B3.D9.85 .D8.A7.D9.84.D8.B6.D9.85.D9.86.D9.8A .28implicit name.29 .D9.84.D9.84.D9.85.D8.AA.D8.AD.D9.88.D9.84 .D8.A7.D9.84.D9.88.D8.AD.D9.8A.D8.AF|it]]</code>، ثم سيُعاد ناتج تنفيذ هذه البنية (block) إلى المتغيّر <code>num</code>. تذكر أنّ الدالة <code>let</code> تعيد قيمة آخر تعليمة في البنية، لذلك لا داعي في هذه الحالة للطباعة أو الإسناد:<syntaxhighlight lang="kotlin"> | ||
< | |||
class Person { | class Person { | ||
var name = "Ahmad" | var name = "Ahmad" | ||
var age = 52 | var age = 52 | ||
} | } | ||
fun main(args: Array<String>) { | fun main(args: Array<String>) { | ||
val person = Person() | val person = Person() | ||
val num = person.let { | val num = person.let { | ||
it.name = "Naser" | it.name = "Naser" | ||
it.age = 19 | it.age = 19 | ||
println(it.name) // bob | println(it.name) // bob | ||
println(it.age) // 19 | println(it.age) // 19 | ||
println() | println() | ||
"OK" | "OK" | ||
} | } | ||
println("$num") // OK | println("$num") // OK | ||
} | } | ||
</syntaxhighlight> | |||
لاحظ استخدام الاسم الضمني it الذي يمثل الوسيط الوحيد عندما يُستخدم داخل بنيات (blocks) الدوال التي تقبل وسيطًا واحدًا، راجع [[Kotlin/lambdas#it: .D8.A7.D9.84.D8.A7.D8.B3.D9.85 .D8.A7.D9.84.D8.B6.D9.85.D9.86.D9.8A .28implicit name.29 .D9.84.D9.84.D9.85.D8.AA.D8.AD.D9.88.D9.84 .D8.A7.D9.84.D9.88.D8.AD.D9.8A.D8.AF|صفح الاسم الضمني it]] لمزيد من المعلومات. | لاحظ استخدام الاسم الضمني <code>[[Kotlin/lambdas#it: .D8.A7.D9.84.D8.A7.D8.B3.D9.85 .D8.A7.D9.84.D8.B6.D9.85.D9.86.D9.8A .28implicit name.29 .D9.84.D9.84.D9.85.D8.AA.D8.AD.D9.88.D9.84 .D8.A7.D9.84.D9.88.D8.AD.D9.8A.D8.AF|it]]</code>الذي يمثل الوسيط الوحيد عندما يُستخدم داخل بنيات (blocks) الدوال التي تقبل وسيطًا واحدًا، راجع [[Kotlin/lambdas#it: .D8.A7.D9.84.D8.A7.D8.B3.D9.85 .D8.A7.D9.84.D8.B6.D9.85.D9.86.D9.8A .28implicit name.29 .D9.84.D9.84.D9.85.D8.AA.D8.AD.D9.88.D9.84 .D8.A7.D9.84.D9.88.D8.AD.D9.8A.D8.AF|صفح الاسم الضمني it]] لمزيد من المعلومات. | ||
== انظر أيضًا == | == انظر أيضًا == | ||
* ()apply: تستدعي بنية (block) الدالة المُحدَّدة وذلك بجعل قيمة this كمستقبِلٍ (receiver) لها وتُعيد قيمة this. | * <code>[[Kotlin/apply|()apply]]</code>: تستدعي بنية (block) الدالة المُحدَّدة وذلك بجعل قيمة <code>this</code> كمستقبِلٍ (receiver) لها وتُعيد قيمة <code>this</code>. | ||
* ()also :تنفِّذ بنية (block) الدالة المُحدَّدة على الكائن الذي استُدعيت عبره، وذلك بجعل قيمة this كوسيط (argument) لها وتُعيد الكائن. | * <code>[[kotlin/also|()also]]</code> :تنفِّذ بنية (block) الدالة المُحدَّدة على الكائن الذي استُدعيت عبره، وذلك بجعل قيمة <code>this</code> كوسيط (argument) لها وتُعيد الكائن. | ||
* ()run: تنفذ بنية (block) الدالة المُحدَّدة ثم تُعيد قيمة ناتجها. | * <code>[[kotlin/run|()run]]</code>: تنفذ بنية (block) الدالة المُحدَّدة ثم تُعيد قيمة ناتجها. | ||
== مصادر == | == مصادر == | ||
* الدالة let() في التوثيق الرسميّ للمكتبة القياسيّة في لغة Kotlin. | * [https://kotlinlang.org/api/latest/jvm/stdlib/kotlin/let.html الدالة let() في التوثيق الرسميّ للمكتبة القياسيّة في لغة Kotlin.] | ||
[[تصنيف:Kotlin]] | [[تصنيف:Kotlin]] | ||
[[تصنيف:Kotlin Functions]] | [[تصنيف:Kotlin Functions]] |
مراجعة 18:39، 9 مايو 2018
تستدعي الدالة let()
بنية (block) الدالة المُحدَّدة وذلك بجعل قيمة this
كوسيط (argument) لها وتعيد ناتج التنفيذ.
عادة ما تُُستخدم let()
لمنع الوصول إلى المتغيرات في مجال الأسماء (namespace) إذ إنّ كل المتغيرات المعرَّفة داخلها لن تكون متاحةً خارج تلك البنية (block).
البنية العامة
inline fun <T, R> T.let(block: (T) -> R): R
يُلاحَظ وجود الكلمة المفتاحية inline
للدلالة على أن هذه الدالة مباشرة، وللمزيد من التفاصيل راجع توثيق الدوال المباشرة (inline functions).
القيم المعادة
تعيد ناتج تنفيذ بنية (block) الدالة المُحدَّدة.
أمثلة
استخدام الدالةlet()
مع الكائنات (objects)
تستدعي الشيفرة الآتية الدالة let()
عبر الكائن person
المُنشَأ من الصنف Person
والذي يحتوي على بيانات أوليّة لكلٍ من خاصيتيّ الاسم (name
) والعمر (age
) مما سيؤدي لتعديلهما بحسب القيم المذكورة في بنية الدالة عبر استدعائهما من الاسم الضمني (implicit name) it
، ثم سيُعاد ناتج تنفيذ هذه البنية (block) إلى المتغيّر num
. تذكر أنّ الدالة let
تعيد قيمة آخر تعليمة في البنية، لذلك لا داعي في هذه الحالة للطباعة أو الإسناد:
class Person {
var name = "Ahmad"
var age = 52
}
fun main(args: Array<String>) {
val person = Person()
val num = person.let {
it.name = "Naser"
it.age = 19
println(it.name) // bob
println(it.age) // 19
println()
"OK"
}
println("$num") // OK
}
لاحظ استخدام الاسم الضمني it
الذي يمثل الوسيط الوحيد عندما يُستخدم داخل بنيات (blocks) الدوال التي تقبل وسيطًا واحدًا، راجع صفح الاسم الضمني it لمزيد من المعلومات.
انظر أيضًا
()apply
: تستدعي بنية (block) الدالة المُحدَّدة وذلك بجعل قيمةthis
كمستقبِلٍ (receiver) لها وتُعيد قيمةthis
.()also
:تنفِّذ بنية (block) الدالة المُحدَّدة على الكائن الذي استُدعيت عبره، وذلك بجعل قيمةthis
كوسيط (argument) لها وتُعيد الكائن.()run
: تنفذ بنية (block) الدالة المُحدَّدة ثم تُعيد قيمة ناتجها.