الفرق بين المراجعتين لصفحة: «Ruby/BasicObject/send»

من موسوعة حسوب
أنشأ الصفحة ب'<noinclude>{{DISPLAYTITLE: التابع <code> __send__</code> في الصنف <code>BasicObject</code> في ruby}}</noinclude> تصنيف: Ruby تصنيف: Rub...'
 
لا ملخص تعديل
سطر 4: سطر 4:
[[تصنيف: Ruby ARGF]]
[[تصنيف: Ruby ARGF]]
يستدعي التابع <code>__send__</code> (يدعى أيضًا <code>send</code>) التابع الممرَّر إليه مع تمرير وسائط محددة إليه.
يستدعي التابع <code>__send__</code> (يدعى أيضًا <code>send</code>) التابع الممرَّر إليه مع تمرير وسائط محددة إليه.
يُستعمَل الاسم <code>__send__</code> الخاص بهذا التابع إذا تعارض الاسم <code>send</code> مع اسم تابع موجود مسبقًا في <code>obj</code>.
يُستعمَل الاسم <code>__send__</code> الخاص بهذا التابع إذا تعارض الاسم <code>send</code> مع اسم تابع موجود مسبقًا في <code>obj</code>.
==البنية العامة==
==البنية العامة==
سطر 12: سطر 13:
  </syntaxhighlight>
  </syntaxhighlight>
==المعاملات==
==المعاملات==
<code>symbol</code>
 
=== <code>symbol</code> ===
اسم التابع المُعرَّف المراد استدعاؤه.
اسم التابع المُعرَّف المراد استدعاؤه.
...<code>args</code>
 
الوسائط المراد تمريرها إلى التابع المحدد في المعامل <code>symbol</code>.
=== ..<code>args</code> ===
<code>string</code>
الوسائط المراد تمريرها إلى التابع المحدد في المعامل <code>symbol</code>
 
=== <code>string</code> ===
سلسلة نصية تمثل اسم التابع المراد استدعاؤه. عندما يُعرّف التابع بواسطة سلسلة نصية (أي باستعمال هذا المعامل)، تحوَّل تلك السلسلة إلى رمز (<code>symbol</code>).
سلسلة نصية تمثل اسم التابع المراد استدعاؤه. عندما يُعرّف التابع بواسطة سلسلة نصية (أي باستعمال هذا المعامل)، تحوَّل تلك السلسلة إلى رمز (<code>symbol</code>).
==القيم المعادة==
==القيم المعادة==
سطر 31: سطر 35:
  </syntaxhighlight>
  </syntaxhighlight>
==انظر أيضًا==
==انظر أيضًا==
* التابع ‎<code>__id__</code>‎‎‎: يعيد مُعرِّفا عدديًا للكائن الذي استُدعي معه.
* التابع ‎[[Ruby/BasicObject/id|<code>__id__</code>‎‎‎]]: يعيد مُعرِّفا عدديًا للكائن الذي استُدعي معه.
* التابع [[Ruby/BasicObject/instance_eval | <code>instance_eval</code>]]: يقدِّر‎ ناتج تنفيذ شيفرة مصدرية للغة روبي معطاة كسلسلة نصية أو ناتج كتلة برمجية (<code>bolck</code>) مُمرَّرة ضمن سياق كائن مُستقبِل (<code>obj</code>).
* التابع [[Ruby/BasicObject/instance_eval | <code>instance_eval</code>]]: يقدِّر‎ ناتج تنفيذ شيفرة مصدرية للغة روبي معطاة كسلسلة نصية أو ناتج كتلة برمجية (block) مُمرَّرة ضمن سياق كائن مُستقبِل (<code>obj</code>).
* التابع [[Ruby/BasicObject/instance_exec | <code>instance_exec</code>]]: ينفِّذ الكتلة البرمجية المُمرَّرة ضمن سياق الكائن المستقبل (<code>obj</code>).
* التابع [[Ruby/BasicObject/instance_exec | <code>instance_exec</code>]]: ينفِّذ الكتلة البرمجية المُمرَّرة ضمن سياق الكائن المستقبل (<code>obj</code>).
==مصادر==
==مصادر==
* قسم التابع __send__ في الصنف BasicObject في توثيق روبي الرسمي.
* [http://ruby-doc.org/core-2.5.1/BasicObject.html#method-i-__send__ قسم التابع __send__ في الصنف BasicObject في توثيق روبي الرسمي.]

مراجعة 18:44، 11 سبتمبر 2018

يستدعي التابع __send__ (يدعى أيضًا send) التابع الممرَّر إليه مع تمرير وسائط محددة إليه.

يُستعمَل الاسم __send__ الخاص بهذا التابع إذا تعارض الاسم send مع اسم تابع موجود مسبقًا في obj.

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

 send(symbol [, args...])  obj
__send__(symbol [, args...])  obj
send(string [, args...])  obj
__send__(string [, args...])  obj

المعاملات

symbol

اسم التابع المُعرَّف المراد استدعاؤه.

..args

الوسائط المراد تمريرها إلى التابع المحدد في المعامل symbol

string

سلسلة نصية تمثل اسم التابع المراد استدعاؤه. عندما يُعرّف التابع بواسطة سلسلة نصية (أي باستعمال هذا المعامل)، تحوَّل تلك السلسلة إلى رمز (symbol).

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

يعاد كائن.

أمثلة

مثال لاستخدام التابع __send__:

 class Klass
 def hello(*args)
   "Hello " + args.join(' ')
 end
end
k = Klass.new
k.send :hello, "gentle", "readers"   #=> "Hello gentle readers"

انظر أيضًا

  • التابع ‎__id__‎‎‎: يعيد مُعرِّفا عدديًا للكائن الذي استُدعي معه.
  • التابع instance_eval: يقدِّر‎ ناتج تنفيذ شيفرة مصدرية للغة روبي معطاة كسلسلة نصية أو ناتج كتلة برمجية (block) مُمرَّرة ضمن سياق كائن مُستقبِل (obj).
  • التابع instance_exec: ينفِّذ الكتلة البرمجية المُمرَّرة ضمن سياق الكائن المستقبل (obj).

مصادر