Ruby 3.0 リファレンスマニュアル

class Ractor

[edit]

要約

並列プログラミングの仕組みを提供するクラスです。

目次

特異メソッド
インスタンスメソッド

特異メソッド

self[sym] -> object | nil[permalink][rdoc][edit]

このメソッドを呼び出した Ractor の Ractor-local storage の sym に対応するデータを取り出します。 sym に対応するデータがなければ nil を返します。

[PARAM] sym:
Ractor-local storage のキーを指定します。
[RETURN]
Ractor-local storage に格納されている値を返します。
self[sym] = val[permalink][rdoc][edit]
[PARAM] sym:
Ractor-local storage のキーを指定します。
[PARAM] val:
格納するデータを指定します。
count -> Integer[permalink][rdoc][edit]

実行中の Ractor の数を返します。

current -> Ractor[permalink][rdoc][edit]

このメソッドを呼び出された Ractor を返します。

main -> Ractor[permalink][rdoc][edit]

main Ractor(プログラムの実行が開始された Ractor)を返します。

main? -> bool[permalink][rdoc][edit]

このメソッドを呼び出した Ractor が main Ractor であるとき、true を返します。

make_shareable(obj, copy: false) -> object[permalink][rdoc][edit]

obj が shareable になるよう変換します。

obj が shareable でない場合、obj と obj が参照する shareable でないオブジェクトをすべて freeze します。

[PARAM] obj:
Shareable にしたいオブジェクトを指定します。
[PARAM] copy:
true の場合、obj を変更する代わりに obj のコピーを作成し shareable にします。
new(*args, name: nil) {|*args| ... } -> Ractor[permalink][rdoc][edit]

Ractor を生成して、ブロックの評価を開始します。生成した Ractor を返します。

[PARAM] args:
ブロックの引数として渡されます。値が shareable である場合はそのインスタンスが、そうでない場合はコピーが試みられた値が渡されます。コピーできない値であった場合は例外が発生します。
[PARAM] name:
Ractor の名前を指定します。
receive -> object[permalink][rdoc][edit]
recv -> object

このメソッドを呼び出した Ractor が受信したメッセージを取り出して返します。メッセージが届くまでブロックします。

他の Ractor から Ractor#send で送られたメッセージを受信します。

receive_if {|msg| ... } -> object[permalink][rdoc][edit]

このメソッドを呼び出した Ractor が受信したメッセージのうち、ブロックの評価結果が真になる最初のメッセージを受信して返します。

select(*ractors, yield_value: nil, move: false) -> [object, object][permalink][rdoc][edit]

引数で指定した Ractor のいずれかが Ractor.yield などで送信可能になるまで待ち、その Ractor と受信したオブジェクトの配列 [Ractor, obj] を返します。受信したのが現在の Ractor 自身であった場合は、Ractor の代わりに :receive シンボルが返ります。 yield_value を指定すると、他の Ractor が Ractor#take を呼んだときにその値が yield され、 [:yield, nil] が返ります。move が真のとき yield_value は移動されます。

shareable?(obj) -> bool[permalink][rdoc][edit]

obj が shareable である場合、true を返します。

[PARAM] obj:
Shareable であるか判定したいオブジェクトを指定します。
store_if_absent(key) { ... } -> object[permalink][rdoc][edit]

このメソッドを呼び出した Ractor の Ractor-local storage の key データがない場合、ブロックを評価した結果を格納します。格納した値を返します。

[PARAM] key:
Ractor-local storage のキーを指定します。
yield(obj, move: false) -> object[permalink][rdoc][edit]

現在の Ractor の outgoing port に obj を送信します。別の Ractor が Ractor#take でこのメッセージを受信するまでブロックします。

[PARAM] obj:
送信するオブジェクトを指定します。
[PARAM] move:
obj を「移動」する場合は true を指定します。

インスタンスメソッド

self << msg, move: false -> self[permalink][rdoc][edit]
send(msg, move: false) -> self

self にメッセージを送信します。送られたメッセージは self が Ractor.receive で受信できます。

[PARAM] msg:
送信するメッセージを指定します。
[PARAM] move:
msg を「移動」する場合は true を指定します。
name -> String[permalink][rdoc][edit]

self の名前を返します。

[SEE_ALSO] Ractor.new

take -> object[permalink][rdoc][edit]

self の outgoing port からメッセージを受信します。 self が Ractor.yield で送ったメッセージ、または self のブロックが返した値を受け取ります。メッセージが届くまでブロックします。