Ruby 1.9.3 リファレンスマニュアル > ライブラリ一覧 > weakrefライブラリ > WeakRefクラス

class WeakRef + Delegator

クラスの継承リスト: WeakRef < Delegator < Object < Kernel < BasicObject

要約

weak reference を実現するクラスです。

WeakRef オブジェクトは与えられたオブジェクトをポイントしますが、 ポイント先のオブジェクトは GC される可能性があります。 アクセスしようとしたときにオブジェクトが GC されていれば WeakRef::RefError が発生します。

delegate も参照してください。

サンプルコード

require 'weakref'

foo = Object.new
ref = WeakRef.new(foo)
ref.some_method_of_foo

特異メソッド

new(orig) -> WeakRef

与えられたオブジェクトを使って自身を初期化します。

[PARAM] orig:
任意のオブジェクトを指定します。

インスタンスメソッド

! -> bool

自身を否定します。

self != obj -> bool

自身が与えられたオブジェクトと等しくない場合は、真を返します。 そうでない場合は、偽を返します。

[PARAM] obj:
比較対象のオブジェクトを指定します。
self == obj -> bool

自身が与えられたオブジェクトと等しい場合は、真を返します。 そうでない場合は、偽を返します。

[PARAM] obj:
比較対象のオブジェクトを指定します。
__getobj__ -> object

自身の参照先のオブジェクトを返します。

[EXCEPTION] WeakRef::RefError:
GC 済みのオブジェクトを参照した場合に発生します。

[SEE_ALSO] delegate

__getobj__ -> object

委譲先のオブジェクトを返します。

本メソッドは、サブクラスで再定義する必要があり、 デフォルトでは NotImplementedError が発生します。

[EXCEPTION] NotImplementedError:
サブクラスにて本メソッドが再定義されていない場合に発生します。
__setobj__(obj) -> ()

与えられたオブジェクトを自身の参照先としてセットします。 内部用のメソッドなので使わないでください。

[PARAM] obj:
任意のオブジェクトを指定します。
__setobj__(obj) -> object

委譲先のオブジェクトをセットします。

[PARAM] obj:
委譲先ののオブジェクトを指定します。
[EXCEPTION] NotImplementedError:
サブクラスにて本メソッドが再定義されていない場合に発生します。
freeze -> self

自身を凍結します。

[SEE_ALSO] Object#freeze

marshal_dump -> object

シリアライゼーションをサポートするためにDelegator#__getobj__ が返すオブジェクトを返します。

marshal_load(obj) -> object

シリアライズされたオブジェクトから、Delegator#__getobj__ が返すオブジェクトを再現します。

[PARAM] obj:
Delegator#marshal_dumpの戻り値のコピー
method_missing(m, *args) -> object

渡されたメソッド名と引数を使って、Delegator#__getobj__ が返すオブジェクトへメソッド委譲を行います。

[PARAM] m:
メソッドの名前(シンボル)
[PARAM] args:
メソッドに渡された引数
[RETURN]
委譲先のメソッドからの返り値

[SEE_ALSO] BasicObject#method_missing

methods -> [Symbol]

そのオブジェクトに対して呼び出せるメソッド名の一覧を返します。 このメソッドは public メソッドおよび protected メソッドの名前を返します。

[SEE_ALSO] Object#methods

protected_methods(all = true) -> [Symbol]

そのオブジェクトが理解できる protected メソッド名の一覧を返します。

[PARAM] all:
偽を指定すると __getobj__ のスーパークラスで定義されたメソッドを除きます。

[SEE_ALSO] Object#protected_methods

public_methods(all = true) -> [Symbol]

そのオブジェクトが理解できる public メソッド名の一覧を返します。

[PARAM] all:
偽を指定すると __getobj__ のスーパークラスで定義されたメソッドを除きます。

[SEE_ALSO] Object#public_methods

respond_to?(m) -> bool

Delegator#__getobj__ が返すオブジェクトが メソッド m を持つとき真を返します。

[PARAM] m:
メソッド名

[SEE_ALSO] Object#respond_to?

respond_to_missing?(m, include_private) -> bool
[PARAM] m:
メソッド名を指定します。
[PARAM] include_private:
真を指定すると private メソッドも調べます。
weakref_alive? -> bool

参照先のオブジェクトがまだ生きていれば真を返します。 GC されていれば偽を返します。

class WeakRef