エントリーの編集
![loading...](https://b.st-hatena.com/bdefb8944296a0957e54cebcfefc25c4dcff9f5f/images/v4/public/common/loading@2x.gif)
エントリーの編集は全ユーザーに共通の機能です。
必ずガイドラインを一読の上ご利用ください。
記事へのコメント3件
- 注目コメント
- 新着コメント
注目コメント算出アルゴリズムの一部にLINEヤフー株式会社の「建設的コメント順位付けモデルAPI」を使用しています
![アプリのスクリーンショット](https://b.st-hatena.com/bdefb8944296a0957e54cebcfefc25c4dcff9f5f/images/v4/public/entry/app-screenshot.png)
- バナー広告なし
- ミュート機能あり
- ダークモード搭載
関連記事
Bug #4909: trapハンドラは再入されてはいけないのではないか? - Ruby master - Ruby Issue Tracking System
以下のプログラムは if intrap == 1 raise "trap nested" end が真になってしまって例外終了してしまう... 以下のプログラムは 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 intr
2014/05/20 リンク