Ruby 1.9.2 リファレンスマニュアル > ライブラリ一覧 > 組み込みライブラリ > Fiberクラス
クラスの継承リスト: Fiber < Object < Kernel < BasicObject
ノンプリエンプティブな軽量スレッド(以下ファイバーと呼ぶ)を提供します。 他の言語では coroutine あるいは semicoroutine と呼ばれることもあります。 Thread と違いユーザレベルスレッドとして実装されています。
Thread クラスが表すスレッドと違い、明示的に指定しない限り ファイバーのコンテキストは切り替わりません。 またファイバーは親子関係を持ちます。Fiber#resume を呼んだファイバーが親になり 呼ばれたファイバーが子になります。親子関係を壊すような遷移(例えば 自分の親の親のファイバーへ切り替えるような処理)はできません。 例外 FiberError が発生します。 できることは
の二通りです。この親子関係は動的なものであり 親ファイバーへコンテキストを切り替えた時点で解消されます。
なお標準添付ライブラリ fiber を require することにより、 コンテキストの切り替えに制限のない Fiber#transfer が使えるようになります。 任意のファイバーにコンテキストを切り替えることができます。
ファイバーが終了するとその親にコンテキストが切り替わります。
ファイバー実行中に例外が発生した場合、親ファイバーに例外が伝播します。
例:
f = Fiber.new do raise StandardError, "hoge" end begin f.resume # ここでも StandardError が発生する。 rescue => e p e.message #=> "hoge" end
ファイバーは処理のあるポイントで他のルーチンにコンテキストを切り替え、またそのポイントから再開する という目的のために使います。 Fiber.new により与えられたブロックとともにファイバーを生成します。 生成したファイバーに対して Fiber#resume を呼ぶことによりコンテキストを切り替えます。 子ファイバーのブロック中で Fiber.yield を呼ぶと親にコンテキストを切り替えます。 Fiber.yield の引数が、親での Fiber#resume の返り値になります。
f = Fiber.new do n = 0 loop do Fiber.yield(n) n += 1 end end 5.times do p f.resume end #=> 0 1 2 3 4
以下は内部イテレータを外部イテレータに変換する例です。 実際 Enumerator は Fiber を用いて実装されています。
def enum2gen(enum) Fiber.new do enum.each{|i| Fiber.yield(i) } end end g = enum2gen(1..100) p g.resume #=> 1 p g.resume #=> 2 p g.resume #=> 3
Thread クラスが表すスレッド間をまたがるファイバーの切り替えはできません。 例外 FiberError が発生します。
f = nil Thread.new do f = Fiber.new{} end.join f.resume #=> t.rb:5:in `resume': fiber called across threads (FiberError) from t.rb:5:in `<main>'
定義 | 説明 | |
---|---|---|
new {|obj| ... } -> Fiber
|
与えられたブロックとともにファイバーを生成して返します。 ブロックは Fiber#resume に与えられた引数をその引数として実行されます。 |
|
yield(*arg = nil) -> object
|
現在のファイバーの親にコンテキストを切り替えます。 |
定義 | 説明 | |
---|---|---|
resume(*arg = nil) -> object
|
自身が表すファイバーへコンテキストを切り替えます。 自身は resume を呼んだファイバーの子となります。 |
!
!=
==
===
=~
__id__
__send__
_dump
class
clone
dclone
display
enum_for
eql?
equal?
extend
freeze
frozen?
hash
initialize
initialize_copy
inspect
instance_eval
instance_exec
instance_of?
instance_variable_defined?
instance_variable_get
instance_variable_set
instance_variables
is_a?
marshal_dump
marshal_load
method
method_missing
methods
must_be
must_be_close_to
must_be_empty
must_be_instance_of
must_be_kind_of
must_be_nil
must_be_same_as
must_be_within_epsilon
must_equal
must_include
must_match
must_raise
must_respond_to
must_send
must_throw
nil?
pretty_inspect
pretty_print
pretty_print_cycle
pretty_print_inspect
pretty_print_instance_variables
private_methods
protected_methods
public_methods
remove_instance_variable
respond_to?
respond_to_missing?
singleton_class
singleton_method_added
singleton_method_removed
singleton_method_undefined
singleton_methods
taint
tainted?
tap
to_a
to_ary
to_hash
to_int
to_io
to_proc
to_regexp
to_s
to_str
to_yaml
to_yaml_properties
to_yaml_style
trust
untaint
untrust
untrusted?
wont_be
wont_be_close_to
wont_be_empty
wont_be_instance_of
wont_be_kind_of
wont_be_nil
wont_be_same_as
wont_be_within_epsilon
wont_equal
wont_include
wont_match
wont_respond_to
定義 | 説明 | ライブラリ |
---|---|---|
alive? -> bool
|
ファイバーが「生きている」時、真を返します。 |
fiber |
current -> Fiber
|
このメソッドが評価されたコンテキストにおける Fiber のインスタンスを返します。 |
fiber |
transfer(*args) -> object
|
自身が表すファイバーへコンテキストを切り替えます。 |
fiber |