44件ヒット
[1-44件を表示]
(0.025秒)
別のキーワード
モジュール
- ObjectSpace (33)
- Process (11)
キーワード
-
clock
_ gettime (11) -
define
_ finalizer (22) -
undefine
_ finalizer (11)
検索結果
先頭4件
-
ObjectSpace
. # define _ finalizer(obj) {|id| . . . } -> Array (27.0) -
obj が解放されるときに実行されるファイナライザ proc を 登録します。同じオブジェクトについて複数回呼ばれたときは置き換えで はなく追加登録されます。固定値 0 と proc を配列にして返します。
...です。
//emlist[悪い例][ruby]{
class Foo
def initialize
ObjectSpace.define_finalizer(self) {
puts "foo"
}
end
end
Foo.new
GC.start
//}
これは、渡された proc の self が obj を参照しつ
づけるため。そのオブジェクトが GC の対象になりません......す。
//emlist[例][ruby]{
class Bar
def Bar.callback
proc {
puts "bar"
}
end
def initialize
ObjectSpace.define_finalizer(self, Bar.callback)
end
end
Bar.new
GC.start
//}
proc の呼び出しで発生した大域脱出(exitや例外)は無視されます。
これは、......発生の有無を確認しておいた方が良いでしょう。
//emlist[例][ruby]{
class Baz
def initialize
ObjectSpace.define_finalizer self, eval(%q{
proc {
raise "baz" rescue puts $!
raise "baz2"
puts "baz3"
}
}, TOPLEVEL_BINDING)
end
end
Baz.... -
ObjectSpace
. # define _ finalizer(obj , proc) -> Array (27.0) -
obj が解放されるときに実行されるファイナライザ proc を 登録します。同じオブジェクトについて複数回呼ばれたときは置き換えで はなく追加登録されます。固定値 0 と proc を配列にして返します。
...です。
//emlist[悪い例][ruby]{
class Foo
def initialize
ObjectSpace.define_finalizer(self) {
puts "foo"
}
end
end
Foo.new
GC.start
//}
これは、渡された proc の self が obj を参照しつ
づけるため。そのオブジェクトが GC の対象になりません......す。
//emlist[例][ruby]{
class Bar
def Bar.callback
proc {
puts "bar"
}
end
def initialize
ObjectSpace.define_finalizer(self, Bar.callback)
end
end
Bar.new
GC.start
//}
proc の呼び出しで発生した大域脱出(exitや例外)は無視されます。
これは、......発生の有無を確認しておいた方が良いでしょう。
//emlist[例][ruby]{
class Baz
def initialize
ObjectSpace.define_finalizer self, eval(%q{
proc {
raise "baz" rescue puts $!
raise "baz2"
puts "baz3"
}
}, TOPLEVEL_BINDING)
end
end
Baz.... -
ObjectSpace
. # undefine _ finalizer(obj) -> object (15.0) -
obj に対するファイナライザをすべて解除します。 obj を返します。
...mple.callback
proc {
puts "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
# ※何も出力されな... -
Process
. # clock _ gettime(clock _ id , unit=:float _ second) -> Float | Integer (9.0) -
POSIX の clock_gettime() 関数の時間を返します。
...レーション:
: :GETRUSAGE_BASED_CLOCK_PROCESS_CPUTIME_ID
SUS で定義されている getrusage() を使います。
getrusage() を RUSAGE_SELF と一緒に使うと、(子プロセスの時間をのぞいた)
getrusage() を呼び出したプロセスだけの CPU 時間が得られます...