الفرق بين المراجعتين لصفحة: «Ruby/InstructionSequence/disasm»
< Ruby | InstructionSequence
لا ملخص تعديل |
جميل-بيلوني (نقاش | مساهمات) ط مراجعة وتدقيق. |
||
| سطر 1: | سطر 1: | ||
<noinclude>{{DISPLAYTITLE: التابع <code>disasm | <noinclude>{{DISPLAYTITLE: التابع <code>InstructionSequence.disasm</code> في روبي}}</noinclude> | ||
[[تصنيف: Ruby]] | [[تصنيف: Ruby]] | ||
[[تصنيف: Ruby Method]] | [[تصنيف: Ruby Method]] | ||
[[تصنيف: Ruby InstructionSequence]] | [[تصنيف: Ruby InstructionSequence]] | ||
يأخذ التابع <code>disasm</code> | يأخذ التابع <code>disasm</code> كائنًا يمكن أن يكون من النوع <code>[[Ruby/Method|Method]]</code> أو من النوع <code>[[Ruby/Proc|Proc]]</code> ويعيد سلسلة نصية تعليمات قابلة للقراءة لهذا المعامل المعطى. | ||
==البنية العامة== | ==البنية العامة== | ||
<syntaxhighlight lang="ruby">disasm(body) → str | <syntaxhighlight lang="ruby">disasm(body) → str | ||
| سطر 9: | سطر 9: | ||
==المعاملات== | ==المعاملات== | ||
===<code>body</code>=== | ===<code>body</code>=== | ||
كائن من النوع | كائن من النوع <code>[[Ruby/Method|Method]]</code> أو من النوع <code>[[Ruby/Proc|Proc]]</code>. | ||
==القيمة | ==القيمة المعادة== | ||
تعاد سلسلة نصية تحوي المعامل <code>body</code> على هيئة تعليمات قابلة للقراءة. | |||
==أمثلة== | ==أمثلة== | ||
مثال على استخدام التابع <code>disasm</code> مع تمرير الكائن <code>[[Ruby/Method|Method]]</code> إليه:<syntaxhighlight lang="ruby"># /tmp/method.rb | |||
مثال على استخدام التابع <code>disasm</code> مع | |||
def hello | def hello | ||
puts "hello, world" | puts "hello, world" | ||
end | end | ||
puts RubyVM::InstructionSequence.disasm(method(:hello))</syntaxhighlight>الناتج سيكون:<syntaxhighlight lang=" | puts RubyVM::InstructionSequence.disasm(method(:hello))</syntaxhighlight>الناتج سيكون:<syntaxhighlight lang="text">== disasm: <RubyVM::InstructionSequence:hello@/tmp/method.rb>============ | ||
0000 trace 8 ( 1) | 0000 trace 8 ( 1) | ||
0002 trace 1 ( 2) | 0002 trace 1 ( 2) | ||
| سطر 26: | سطر 25: | ||
0007 send :puts, 1, nil, 8, <ic:0> | 0007 send :puts, 1, nil, 8, <ic:0> | ||
0013 trace 16 ( 3) | 0013 trace 16 ( 3) | ||
0015 leave ( 2)</syntaxhighlight> | 0015 leave ( 2)</syntaxhighlight>مثال آخر على استخدام التابع <code>disasm</code>مع الكائن <code>[[Ruby/Proc|Proc]]</code> إليه:<syntaxhighlight lang="ruby"># /tmp/proc.rb | ||
مثال على استخدام التابع <code>disasm</code>مع | |||
p = proc { num = 1 + 2 } | p = proc { num = 1 + 2 } | ||
puts RubyVM::InstructionSequence.disasm(p)</syntaxhighlight>الناتج سيكون:<syntaxhighlight lang=" | puts RubyVM::InstructionSequence.disasm(p)</syntaxhighlight>الناتج سيكون:<syntaxhighlight lang="text">== disasm: <RubyVM::InstructionSequence:block in <main>@/tmp/proc.rb>=== | ||
== catch table | == catch table | ||
| catch type: redo st: 0000 ed: 0012 sp: 0000 cont: 0000 | | catch type: redo st: 0000 ed: 0012 sp: 0000 cont: 0000 | ||
| سطر 45: | سطر 41: | ||
0009 setlocal num, 0 | 0009 setlocal num, 0 | ||
0012 leave</syntaxhighlight> | 0012 leave</syntaxhighlight> | ||
==انظر | ==انظر أيضًا== | ||
*التابع <code>[[Ruby/InstructionSequence/disassemble|disassemble]]</code>: يأخذ | *التابع <code>[[Ruby/InstructionSequence/disassemble|disassemble]]</code>: يأخذ المعامل <code>body</code>، والذي سيكون إما كائنًا من النوع <code>[[Ruby/Method|Method]]</code>، أو من النوع <code>[[Ruby/Proc|Proc]]</code>، ثم يُعيد سلسلة نصية تحوي هذا المعامل على هيئة تعليمات قابلة للقراءة. | ||
==مصادر== | ==مصادر== | ||
*[http://ruby-doc.org/core-2.5.1/RubyVM/InstructionSequence.html#method-i-disasm قسم | *[http://ruby-doc.org/core-2.5.1/RubyVM/InstructionSequence.html#method-i-disasm قسم التابع disasm في الصنف InstructionSequence في توثيق روبي الرسمي.] | ||
المراجعة الحالية بتاريخ 06:57، 4 ديسمبر 2018
يأخذ التابع disasm كائنًا يمكن أن يكون من النوع Method أو من النوع Proc ويعيد سلسلة نصية تعليمات قابلة للقراءة لهذا المعامل المعطى.
البنية العامة
disasm(body) → str
disassemble(body) → str
المعاملات
body
كائن من النوع Method أو من النوع Proc.
القيمة المعادة
تعاد سلسلة نصية تحوي المعامل body على هيئة تعليمات قابلة للقراءة.
أمثلة
مثال على استخدام التابع disasm مع تمرير الكائن Method إليه:
# /tmp/method.rb
def hello
puts "hello, world"
end
puts RubyVM::InstructionSequence.disasm(method(:hello))
الناتج سيكون:
== disasm: <RubyVM::InstructionSequence:hello@/tmp/method.rb>============
0000 trace 8 ( 1)
0002 trace 1 ( 2)
0004 putself
0005 putstring "hello, world"
0007 send :puts, 1, nil, 8, <ic:0>
0013 trace 16 ( 3)
0015 leave ( 2)
مثال آخر على استخدام التابع disasmمع الكائن Proc إليه:
# /tmp/proc.rb
p = proc { num = 1 + 2 }
puts RubyVM::InstructionSequence.disasm(p)
الناتج سيكون:
== disasm: <RubyVM::InstructionSequence:block in <main>@/tmp/proc.rb>===
== catch table
| catch type: redo st: 0000 ed: 0012 sp: 0000 cont: 0000
| catch type: next st: 0000 ed: 0012 sp: 0000 cont: 0012
|------------------------------------------------------------------------
local table (size: 2, argc: 0 [opts: 0, rest: -1, post: 0, block: -1] s1)
[ 2] num
0000 trace 1 ( 1)
0002 putobject 1
0004 putobject 2
0006 opt_plus <ic:1>
0008 dup
0009 setlocal num, 0
0012 leave
انظر أيضًا
- التابع
disassemble: يأخذ المعاملbody، والذي سيكون إما كائنًا من النوعMethod، أو من النوعProc، ثم يُعيد سلسلة نصية تحوي هذا المعامل على هيئة تعليمات قابلة للقراءة.