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

من موسوعة حسوب
لا ملخص تعديل
طلا ملخص تعديل
 
(مراجعتان متوسطتان بواسطة مستخدمين اثنين آخرين غير معروضتين)
سطر 1: سطر 1:
<noinclude>{{DISPLAYTITLE: التابع <code>bind‎</code> الخاص بالصنف <code>UnboundMethod</code> في روبي}}</noinclude>
<noinclude>{{DISPLAYTITLE: التابع <code>UnboundMethod.bind‎</code> في روبي}}</noinclude>
[[تصنيف: Ruby]]
[[تصنيف: Ruby]]
[[تصنيف: Ruby Method]]
[[تصنيف: Ruby Method]]
[[تصنيف: Ruby UnboundMethod]]
[[تصنيف: Ruby UnboundMethod]]
يربط التابع <code>bind</code> [[Ruby/UnboundMethod|التابع الحر]] <code>umeth</code> بالكائن <code>obj</code> (انظر فقرة البنية العامة). إذا كان <code>Klass</code> هو الصنف الذي استُنسخ منه [[Ruby/UnboundMethod|التابع الحر]] <code>umeth</code>، فيجب أن يساوي التعبير <code>obj.kind_of?(Klass)</code> القيمة true.
يربط التابع <code>bind</code> [[Ruby/UnboundMethod|التابعَ الحرَّ]] الذي استُدعي معه بالكائن الذي مُرِّر إليه.


 
إذا كان <code>Klass</code> هو الصنف الذي أُنشئ منه [[Ruby/UnboundMethod|التابع الحر]]، فيجب أن يساوي التعبير <code>obj.kind_of?(Klass)‎</code> القيمة <code>true</code>.
 
<code>produces:</code>
 
<syntaxhighlight lang="ruby">In test, class = C
In test, class = B
prog.rb:16:in `bind': bind argument must be an instance of B (TypeError)
from prog.rb:16‎</syntaxhighlight>
==البنية العامة==
==البنية العامة==
<syntaxhighlight lang="ruby">bind(obj) → method‎</syntaxhighlight>
<syntaxhighlight lang="ruby">bind(obj) → method‎</syntaxhighlight>
==المعاملات==
==المعاملات==
===<code>obj‎</code>===
===<code>obj‎</code>===
==القيمة المُعادة==
كائن يراد ربطه بالتابع الحر.
 
==القيمة المعادة==
يعاد التابع الناتج عن ربط التابع الحر بالكائن <code>obj</code>.
 
==أمثلة==
==أمثلة==
مثال على استخدام التابع <code>bind‎</code>:
مثال على استخدام التابع <code>bind‎</code>:
سطر 35: سطر 32:
bm.call
bm.call
bm = um.bind(A.new)
bm = um.bind(A.new)
bm.call‎</syntaxhighlight>
bm.call‎</syntaxhighlight>الناتج:<syntaxhighlight lang="text">In test, class = C
==انظر أيضا==
In test, class = B
* التابع <code>[[Ruby/UnboundMethod/arity|arity]]</code>: يعيد التابع <code>arity</code> مؤشرا لعدد الوسائط المقبولة من قبل التابع. يعيد عددًا صحيحًا غير سالب للتوابع التي تأخذ عددًا محددًا من الوسائطا. بالنسبة لتوابع روبي التي تأخذ عددًا متغيرًا من الوسائط، يًعاد العدد -n-1، حيث n هو عدد الوسائط المطلوبة. الوسائط المسماة (Keyword arguments) ستُعد وسيطاً إضافيًا واحدًا، وسيكون ذلك الوسيط إلزاميا إن كان أيٌّ من الوسائط المسماة كذلك. بالنسبة للتوابع المكتوبة بلغة C، سيُعاد العدد -1 إن كانت استدعاء تلك التوابع يأخذ عددًا متغيرًا من الوسائط.
prog.rb:16:in `bind': bind argument must be an instance of B (TypeError)
* التابع <code>[[Ruby/UnboundMethod/clone|clone]]</code>: يعيد التابع <code>clone</code> نسخة من هذا التابع.
from prog.rb:16‎</syntaxhighlight>
==انظر أيضًا==
* التابع <code>[[Ruby/UnboundMethod/clone|clone]]</code>: يعيد نسخة من التابع.
==مصادر==
==مصادر==
*[http://ruby-doc.org/core-2.5.1/UnboundMethod.html#method-i-bind قسم التابع bind‎ في الصنف UnboundMethod‎ في توثيق روبي الرسمي.]
*[http://ruby-doc.org/core-2.5.1/UnboundMethod.html#method-i-bind قسم التابع bind‎ في الصنف UnboundMethod‎ في توثيق روبي الرسمي.]

المراجعة الحالية بتاريخ 07:29، 8 ديسمبر 2018

يربط التابع bind التابعَ الحرَّ الذي استُدعي معه بالكائن الذي مُرِّر إليه.

إذا كان Klass هو الصنف الذي أُنشئ منه التابع الحر، فيجب أن يساوي التعبير obj.kind_of?(Klass)‎ القيمة true.

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

bind(obj)  method

المعاملات

obj‎

كائن يراد ربطه بالتابع الحر.

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

يعاد التابع الناتج عن ربط التابع الحر بالكائن obj.

أمثلة

مثال على استخدام التابع bind‎:

class A
  def test
    puts "In test, class = #{self.class}"
  end
end
class B < A
end
class C < B
end
um = B.instance_method(:test)
bm = um.bind(C.new)
bm.call
bm = um.bind(B.new)
bm.call
bm = um.bind(A.new)
bm.call

الناتج:

In test, class = C
In test, class = B
prog.rb:16:in `bind': bind argument must be an instance of B (TypeError)
 from prog.rb:16‎

انظر أيضًا

  • التابع clone: يعيد نسخة من التابع.

مصادر