るりまサーチ

最速Rubyリファレンスマニュアル検索!
176件ヒット [1-100件を表示] (0.076秒)
トップページ > ライブラリ:ビルトイン[x] > クエリ:p[x] > クエリ:ObjectSpace[x]

別のキーワード

  1. openssl p
  2. openssl p=
  3. fileutils mkdir_p
  4. _builtin p
  5. kernel p

クラス

モジュール

キーワード

検索結果

<< 1 2 > >>

ObjectSpace (44002.0)

全てのオブジェクトを操作するためのモジュールです。

全てのオブジェクトを操作するためのモジュールです。

ObjectSpace.#define_finalizer(obj, proc) -> Array (24120.0)

obj が解放されるときに実行されるファイナライザ proc を 登録します。同じオブジェクトについて複数回呼ばれたときは置き換えで はなく追加登録されます。固定値 0 と proc を配列にして返します。

...obj が解放されるときに実行されるファイナライザ proc を
登録します。同じオブジェクトについて複数回呼ばれたときは置き換えで
はなく追加登録されます。固定値 0 と proc を配列にして返します。

ブロックを指定した場...
...ナライザを登録するのは難しいでしょう。

@param obj ファイナライザを登録したいオブジェクトを指定します。

@param proc ファイナライザとして Proc オブジェクトを指定します。proc は obj の回収時に obj の ID を引数として実...
...{
class Foo
def initialize
ObjectSpace
.define_finalizer(self) {
p
uts "foo"
}
end
end
Foo.new
GC.start
//}

これは、渡された proc の self が obj を参照しつ
づけるため。そのオブジェクトが GC の対象になりません。

tempfile は、ファイナラ...

ObjectSpace.#garbage_collect(full_mark: true, immediate_sweep: true) -> nil (24102.0)

どこからも参照されなくなったオブジェクトを回収します。 GC.start と同じです。

...回収します。
GC.start と同じです。

@param full_mark マイナー GC を動作させる場合は false を、そうでない場
合は true を指定します。

@param immediate_sweep sweep を遅らせる(Lazy Sweep を行う)場合は false
...

ObjectSpace.#each_object -> Enumerator (24050.0)

指定された klass と Object#kind_of? の関係にある全ての オブジェクトに対して繰り返します。引数が省略された時には全てのオブ ジェクトに対して繰り返します。 繰り返した数を返します。

...

@param klass クラスかモジュールを指定します。

//emlist[例: ブロックなし][ruby]{
p
ObjectSpace.each_object
# => #<Enumerator: ObjectSpace:each_object(false)>
//}

//emlist[例: 全てのオブジェクトを扱う][ruby]{
ObjectSpace
.each_object.take(5).each { |x| p x }
c...
...ount = ObjectSpace.each_object { |x| x }
p
uts "Total count: #{count}"

# => "scope"
# => "scopes"
# => "sym"
# => "class_names"
# => "@corrections"
# => Total count: 9938
//}

//emlist[例: 任意のクラスを扱う][ruby]{
P
erson = Struct.new(:name)
s1 = Person.new("tanaka")
s2 = Person.new("sato...
...")

count = ObjectSpace.each_object(Person) { |x| p x }
p
uts "Total count: #{count}"

# => #<struct Person name="sato">
# => #<struct Person name="tanaka">
# => Total count: 2
//}...

ObjectSpace.#each_object {|object| ...} -> Integer (24050.0)

指定された klass と Object#kind_of? の関係にある全ての オブジェクトに対して繰り返します。引数が省略された時には全てのオブ ジェクトに対して繰り返します。 繰り返した数を返します。

...

@param klass クラスかモジュールを指定します。

//emlist[例: ブロックなし][ruby]{
p
ObjectSpace.each_object
# => #<Enumerator: ObjectSpace:each_object(false)>
//}

//emlist[例: 全てのオブジェクトを扱う][ruby]{
ObjectSpace
.each_object.take(5).each { |x| p x }
c...
...ount = ObjectSpace.each_object { |x| x }
p
uts "Total count: #{count}"

# => "scope"
# => "scopes"
# => "sym"
# => "class_names"
# => "@corrections"
# => Total count: 9938
//}

//emlist[例: 任意のクラスを扱う][ruby]{
P
erson = Struct.new(:name)
s1 = Person.new("tanaka")
s2 = Person.new("sato...
...")

count = ObjectSpace.each_object(Person) { |x| p x }
p
uts "Total count: #{count}"

# => #<struct Person name="sato">
# => #<struct Person name="tanaka">
# => Total count: 2
//}...

絞り込み条件を変える

ObjectSpace.#each_object(klass) -> Enumerator (24050.0)

指定された klass と Object#kind_of? の関係にある全ての オブジェクトに対して繰り返します。引数が省略された時には全てのオブ ジェクトに対して繰り返します。 繰り返した数を返します。

...

@param klass クラスかモジュールを指定します。

//emlist[例: ブロックなし][ruby]{
p
ObjectSpace.each_object
# => #<Enumerator: ObjectSpace:each_object(false)>
//}

//emlist[例: 全てのオブジェクトを扱う][ruby]{
ObjectSpace
.each_object.take(5).each { |x| p x }
c...
...ount = ObjectSpace.each_object { |x| x }
p
uts "Total count: #{count}"

# => "scope"
# => "scopes"
# => "sym"
# => "class_names"
# => "@corrections"
# => Total count: 9938
//}

//emlist[例: 任意のクラスを扱う][ruby]{
P
erson = Struct.new(:name)
s1 = Person.new("tanaka")
s2 = Person.new("sato...
...")

count = ObjectSpace.each_object(Person) { |x| p x }
p
uts "Total count: #{count}"

# => #<struct Person name="sato">
# => #<struct Person name="tanaka">
# => Total count: 2
//}...

ObjectSpace.#each_object(klass) {|object| ...} -> Integer (24050.0)

指定された klass と Object#kind_of? の関係にある全ての オブジェクトに対して繰り返します。引数が省略された時には全てのオブ ジェクトに対して繰り返します。 繰り返した数を返します。

...

@param klass クラスかモジュールを指定します。

//emlist[例: ブロックなし][ruby]{
p
ObjectSpace.each_object
# => #<Enumerator: ObjectSpace:each_object(false)>
//}

//emlist[例: 全てのオブジェクトを扱う][ruby]{
ObjectSpace
.each_object.take(5).each { |x| p x }
c...
...ount = ObjectSpace.each_object { |x| x }
p
uts "Total count: #{count}"

# => "scope"
# => "scopes"
# => "sym"
# => "class_names"
# => "@corrections"
# => Total count: 9938
//}

//emlist[例: 任意のクラスを扱う][ruby]{
P
erson = Struct.new(:name)
s1 = Person.new("tanaka")
s2 = Person.new("sato...
...")

count = ObjectSpace.each_object(Person) { |x| p x }
p
uts "Total count: #{count}"

# => #<struct Person name="sato">
# => #<struct Person name="tanaka">
# => Total count: 2
//}...

ObjectSpace.#define_finalizer(obj) {|id| ...} -> Array (24020.0)

obj が解放されるときに実行されるファイナライザ proc を 登録します。同じオブジェクトについて複数回呼ばれたときは置き換えで はなく追加登録されます。固定値 0 と proc を配列にして返します。

...obj が解放されるときに実行されるファイナライザ proc を
登録します。同じオブジェクトについて複数回呼ばれたときは置き換えで
はなく追加登録されます。固定値 0 と proc を配列にして返します。

ブロックを指定した場...
...ナライザを登録するのは難しいでしょう。

@param obj ファイナライザを登録したいオブジェクトを指定します。

@param proc ファイナライザとして Proc オブジェクトを指定します。proc は obj の回収時に obj の ID を引数として実...
...{
class Foo
def initialize
ObjectSpace
.define_finalizer(self) {
p
uts "foo"
}
end
end
Foo.new
GC.start
//}

これは、渡された proc の self が obj を参照しつ
づけるため。そのオブジェクトが GC の対象になりません。

tempfile は、ファイナラ...

ObjectSpace.#undefine_finalizer(obj) -> object (24020.0)

obj に対するファイナライザをすべて解除します。 obj を返します。

...@param obj ファイナライザを解除したいオブジェクトを指定します。

//emlist[例][ruby]{
class Sample
def Sample.callback
p
roc {
p
uts "finalize"
}
end

def initialize
ObjectSpace
.define_finalizer(self, Sample.callback)
end

def undef
ObjectSpace
...
....undefine_finalizer(self)
end
end

Sample.new
GC.start
# => finalize

Sample.new
sample.undef
GC.start
# ※何も出力されない
//}

@see ObjectSpace.#define_finalizer...

ObjectSpace.#_id2ref(id) -> object (24014.0)

オブジェクト ID(BasicObject#__id__)からオブジェクトを得ます。

...id__)からオブジェクトを得ます。

@param id 取得したいオブジェクトの ID を整数で指定します。

@raise RangeError 対応するオブジェクトが存在しなければ発生します。

//emlist[例][ruby]{
a = "hoge"
p
ObjectSpace._id2ref(a.__id__) #=> "hoge"
//}...

絞り込み条件を変える

<< 1 2 > >>