From: "kosaki (Motohiro KOSAKI)" Date: 2012-11-26T20:04:21+09:00 Subject: [ruby-dev:46629] [ruby-trunk - Bug #4909][Closed] trapハンドラは再入されてはいけないのではないか? Issue #4909 has been updated by kosaki (Motohiro KOSAKI). Status changed from Assigned to Closed #6009と重複しているので、こちらのチケットは閉じますね。英語のほうを残します。 ---------------------------------------- Bug #4909: trapハンドラは再入されてはいけないのではないか? https://bugs.ruby-lang.org/issues/4909#change-33952 Author: kosaki (Motohiro KOSAKI) Status: Closed Priority: Normal Assignee: kosaki (Motohiro KOSAKI) Category: core Target version: 2.0.0 ruby -v: - 以下のプログラムは if intrap == 1 raise "trap nested" end が真になってしまって例外終了してしまうのですが、これは起きてはいけないのではないでしょうか。 以下の二点が問題だと考えます。 1)このプログラムのようにシグナルを連続して配送されるとスタックオーバーフローを引き起こせる 2)Rubyレベルでsigprocmask()に相当するシグナルブロッキング操作が提供されていないため、 正しいトラップハンドラを書くのが、ほぼ不可能になっている C言語ですら、シグナルハンドラ実行中はシグナルが自動的にマスクされるんですから、Rubyでも 同レベルの配慮はMRIがおこなうべきだと思います。 --------------------------------------------------------------------- n = 0 intrap = 0 parent = $$ trap(:USR1) { if intrap == 1 raise "trap nested" end intrap = 1 10000.times { n += 1 } intrap = 0 } fork do Process.kill(:USR1, parent) while true end sleep 100 ---------------------------------------------------- -- http://bugs.ruby-lang.org/