[#45703] test_advise failure on GNU/Linux — Tanaka Akira <tanaka.akira@...>

今朝、気がついたのですが、手元で test_advise が失敗します。

11 messages 2012/06/05
[#45705] Re: test_advise failure on GNU/Linux — KOSAKI Motohiro <kosaki.motohiro@...> 2012/06/06

小崎です

[#45735] [ruby-trunk - Feature #6587][Open] proposal: adding new methods File.rootname and Pathname#rootname — "usa (Usaku NAKAMURA)" <usa@...>

14 messages 2012/06/14

[#45745] Re: [ruby-changes:24028] yugui:r36079 (trunk): Embedding CRuby interpreter without internal headers has been difficult — SASADA Koichi <ko1@...>

見逃していました.

19 messages 2012/06/14
[#45747] Re: [ruby-changes:24028] yugui:r36079 (trunk): Embedding CRuby interpreter without internal headers has been difficult — Yugui <yugui@...> 2012/06/15

2012/6/15 SASADA Koichi <ko1@atdot.net>:

[#45748] Re: [ruby-changes:24028] yugui:r36079 (trunk): Embedding CRuby interpreter without internal headers has been difficult — SASADA Koichi <ko1@...> 2012/06/15

 ささだです.

[#45794] :new_pgroup and :pgroup option for spawn. — Tanaka Akira <akr@...>

process.c で気がついたのですが、spawn に Windows 用の :new_pgroup というオプションが

12 messages 2012/06/23
[#45800] Re: :new_pgroup and :pgroup option for spawn. — "U.Nakamura" <usa@...> 2012/06/25

こんにちは、なかむら(う)です。

[#45818] [ruby-trunk - Feature #6643][Open] io.seek(off, :end) — "akr (Akira Tanaka)" <akr@...>

30 messages 2012/06/25

[ruby-dev:45821] Re: 非同期割り込みに対する対処案(日本語版)

From: SASADA Koichi <ko1@...>
Date: 2012-06-25 12:01:55 UTC
List: ruby-dev #45821
 ささだです.

 早速の回答,ありがとうございます.

 (1) はコメントとして書いておこう.

(2012/06/25 20:32), Tanaka Akira wrote:
> ブロックする操作やそれ以外の場所を safe point とするかどうかを制御する感じに
> だったように思います。

 それ以外の場所を safe point にする API が不足しているでしょうか?(私
の見落とし?)

 具体的には,Thread.delay_interrupt の逆.


>>  あと,よくよく考えると,Thread.blocking_uninterruptible などで,klass
>> の指定が n 個ネストすると,非同期割り込みが起こる度に n 回チェックする必
>> 要がある気がします.包含関係があるので,単純にそうではないんですが.継承
>> 関係を考えると,ハッシュで O(1),というわけにもいかない(飛んできた例外
>> オブジェクトの継承木の高さが m 個の場合,O(m) でいけるか).
> 
> そうですね。
> 
>>  また,[ruby-talk:294917] ではキューで管理するべき,ということでした
>> が,種類によって割り込みが追い越す可能性があります(例えば,TimeoutError
>> がブロックされており,キューに貯まっているとき,InterruptError が来たら
>> どうなるか).
> 
> 追い越すのではないかと思います。
> 
>> (5) チェックのコストをどう考えるか(O(m) は甘受すべきコストか)
> 
> 非同期イベントはそのコストが問題になるほど頻繁に使うべきものではないんじゃないでしょうか。
> 
> 原則的には、プロセスの終了のためにのみ使うべきだと思っています、

 つまり,このキューは殆どの場合空であるため,もしくは空にするべきである
ため,コストに関してはあまり気にならないんじゃないの,ということですね.


>> (6) 追い越しが発生するとき,どうすると良いか
> 
> 追い越せばいいんじゃないでしょうか。
> なにを問題と感じているのかわかりません。

 何かの弾みでキューに例外が詰まってきたとき,ナイーブに作るとかなりオー
バヘッドがかかりそうだなぁ,と思ったんですが,気合い入れて結果をきちんと
キャッシュすればなんとかなるかな....


>>  あと,[ruby-talk:294917] では "It is because Thread.check_interrupt
>> with blocking operations causes race conditions." と,race が起こるとか
>> いてあるんですが,これどういう話でしたっけ.
> 
> あぁ、race もありますが、もっとあからさまにブロックしている最中に
> 中断できなければならないというほうがわかりやすい必要性かもしれません。
> 
> race は、ブロックする直前や直後にシグナルが来たときの話を想定していました。
> もし Binary Hacks を持っているなら「sigsafeでシグナル処理を安全にする」という
> のを読んでみてください。

 なるほど,その話でしたか.了解です.

-- 
// SASADA Koichi at atdot dot net



In This Thread