الفرق بين المراجعتين لصفحة: «Kotlin/run»
< Kotlin
لا ملخص تعديل |
جميل-بيلوني (نقاش | مساهمات) طلا ملخص تعديل |
||
(5 مراجعات متوسطة بواسطة 3 مستخدمين غير معروضة) | |||
سطر 1: | سطر 1: | ||
<noinclude>{{DISPLAYTITLE: الدالة | <noinclude>{{DISPLAYTITLE: الدالة <code>run()</code> في Kotlin}}</noinclude> | ||
يمكن استخدام <code>run()</code> بطريقتين: | يمكن استخدام الدالة <code>run()</code> بطريقتين: | ||
* | * استدعاء بنية (block) الدالة المُحدَّدة وذلك بجعل قيمة <code>this</code> كمستقبِلٍ (receiver) له وإعادة قيمة ناتج البنية. | ||
* | * استدعاء بنية (block) الدالة المُحدَّدة وإعادة ناتجها. | ||
== البنية العام == | == البنية العام == | ||
<syntaxhighlight lang="kotlin"> | <syntaxhighlight lang="kotlin"> | ||
inline fun <T, R> T.run(block: T.() -> R): R | inline fun <T, R> T.run(block: T.() -> R): R | ||
inline fun <R> run(block: () -> R): R | inline fun <R> run(block: () -> R): R | ||
</syntaxhighlight>يُلاحَظ وجود الكلمة المفتاحية <code>inline</code> للدلالة على أن هذه الدالة مباشرة، وللمزيد من التفاصيل راجع [[Kotlin/inline functions|توثيق الدوال المباشرة (inline functions)]]. | </syntaxhighlight>يُلاحَظ وجود الكلمة المفتاحية <code>inline</code> للدلالة على أن هذه الدالة مباشرة، وللمزيد من التفاصيل راجع [[Kotlin/inline functions|توثيق الدوال المباشرة (inline functions)]]. | ||
== المعاملات == | |||
=== <code>block</code> === | |||
الكتلة البرمجية المراد استدعاؤها وتنفيذها. | |||
== القيم المعادة == | == القيم المعادة == | ||
ناتج بنية (block) الدالة المُحدَّدة. | يعاد ناتج بنية (block) الدالة المُحدَّدة في المعامل <code>block</code>. | ||
== أمثلة == | == أمثلة == | ||
'''مثالٌ على استخدام الدالة <code>run()</code> وفق الشكل الاول:''' | |||
تستدعي الشيفرة الآتية الدالة <code>run()</code> عبر الكائن <code>person</code> المُنشَأ من الصنف <code>Person</code> الذي يحتوي على بيانات أوليّة لكلٍ من خاصيتيّ الاسم (name) والعمر(age) مما سيؤدي لتعديلهما بحسب القيم المذكورة في بنية الدالة ثم سيُعاد ناتج بنية (block) الدالة إلى المتغير <code>a</code>:<syntaxhighlight lang="kotlin"> | |||
تستدعي الشيفرة الآتية الدالة <code>run()</code> عبر الكائن <code>person</code> المُنشَأ من الصنف <code>Person</code> الذي يحتوي على بيانات أوليّة لكلٍ من خاصيتيّ الاسم ( | class Person { | ||
var name = "أحمد" | |||
var age = 52 | |||
} | } | ||
fun main(args: Array<String>) { | |||
val person = Person() | |||
val a = person.run { | |||
name = "ناصر" | |||
age = 19 | |||
name + " " + age | |||
} | |||
println(a) // ناصر 19 | |||
} | } | ||
</syntaxhighlight> | </syntaxhighlight>'''مثالٌ على استخدام الدالة <code>run()</code> وفق الشكل الثاني:''' | ||
تستخدم الشيفرة الآتية الدالة <code>run()</code> لتنفيذ بنية (block) برمجية تُعرّف متغيرين باسم <code>name</code> و <code>age</code> ثم تطبع قيمتيهما:<syntaxhighlight lang="kotlin"> | |||
fun main(args: Array<String>) { | fun main(args: Array<String>) { | ||
run { | |||
val name = "أحمد" | |||
val age = 14 | |||
print(message = name + " " + age) // أحمد 14 | |||
} | |||
} | } | ||
</syntaxhighlight> | </syntaxhighlight> | ||
== انظر أيضًا == | == انظر أيضًا == | ||
* <code>[[Kotlin/apply|()apply]]</code>: تستدعي بنية (block) الدالة المُحدَّدة وذلك بجعل قيمة <code>this</code> كمستقبِلٍ (receiver) لها وتُعيد قيمة <code>this</code>. | * الدالة <code>[[Kotlin/apply|()apply]]</code>: تستدعي بنية (block) الدالة المُحدَّدة وذلك بجعل قيمة <code>this</code> كمستقبِلٍ (receiver) لها وتُعيد قيمة <code>this</code>. | ||
== مصادر == | == مصادر == | ||
* صفحة الدالة run() في التوثيق الرسميّ للمكتبة القياسيّة في لغة Kotlin. | * [https://kotlinlang.org/api/latest/jvm/stdlib/kotlin/run.html صفحة الدالة run() في التوثيق الرسميّ للمكتبة القياسيّة في لغة Kotlin.] | ||
[[تصنيف:Kotlin]] | [[تصنيف:Kotlin]] | ||
[[تصنيف:Kotlin | [[تصنيف:Kotlin Function]] |
المراجعة الحالية بتاريخ 06:27، 8 سبتمبر 2018
يمكن استخدام الدالة run()
بطريقتين:
- استدعاء بنية (block) الدالة المُحدَّدة وذلك بجعل قيمة
this
كمستقبِلٍ (receiver) له وإعادة قيمة ناتج البنية. - استدعاء بنية (block) الدالة المُحدَّدة وإعادة ناتجها.
البنية العام
inline fun <T, R> T.run(block: T.() -> R): R
inline fun <R> run(block: () -> R): R
يُلاحَظ وجود الكلمة المفتاحية inline
للدلالة على أن هذه الدالة مباشرة، وللمزيد من التفاصيل راجع توثيق الدوال المباشرة (inline functions).
المعاملات
block
الكتلة البرمجية المراد استدعاؤها وتنفيذها.
القيم المعادة
يعاد ناتج بنية (block) الدالة المُحدَّدة في المعامل block
.
أمثلة
مثالٌ على استخدام الدالة run()
وفق الشكل الاول:
تستدعي الشيفرة الآتية الدالة run()
عبر الكائن person
المُنشَأ من الصنف Person
الذي يحتوي على بيانات أوليّة لكلٍ من خاصيتيّ الاسم (name) والعمر(age) مما سيؤدي لتعديلهما بحسب القيم المذكورة في بنية الدالة ثم سيُعاد ناتج بنية (block) الدالة إلى المتغير a
:
class Person {
var name = "أحمد"
var age = 52
}
fun main(args: Array<String>) {
val person = Person()
val a = person.run {
name = "ناصر"
age = 19
name + " " + age
}
println(a) // ناصر 19
}
مثالٌ على استخدام الدالة run()
وفق الشكل الثاني:
تستخدم الشيفرة الآتية الدالة run()
لتنفيذ بنية (block) برمجية تُعرّف متغيرين باسم name
و age
ثم تطبع قيمتيهما:
fun main(args: Array<String>) {
run {
val name = "أحمد"
val age = 14
print(message = name + " " + age) // أحمد 14
}
}
انظر أيضًا
- الدالة
()apply
: تستدعي بنية (block) الدالة المُحدَّدة وذلك بجعل قيمةthis
كمستقبِلٍ (receiver) لها وتُعيد قيمةthis
.