[#28290] [Oniguruma] Version 4.0.0 — "K.Kosako" <sndgk393@...>
まつもとさん、
7 messages
2006/02/02
[#28296] packing small Struct — Tanaka Akira <akr@...17n.org>
しばらく前に思い付いたのですが、メモリ消費を押さえるために、
5 messages
2006/02/04
[#28337] constant look up order in CVS HEAD — Yukihiro Matsumoto <matz@...>
まつもと ゆきひろです
15 messages
2006/02/18
[#28338] Re: constant look up order in CVS HEAD
— Tanaka Akira <akr@...17n.org>
2006/02/19
In article <1140229116.805371.31930.nullmailer@x31.priv.netlab.jp>,
[#28341] Re: constant look up order in CVS HEAD
— GOTOU Yuuzou <gotoyuzo@...>
2006/02/19
In message <87lkw8xfay.fsf@m17n.org>,
[#28342] Re: constant look up order in CVS HEAD
— Yukihiro Matsumoto <matz@...>
2006/02/19
まつもと ゆきひろです
[#28347] Re: constant look up order in CVS HEAD
— Tanaka Akira <akr@...17n.org>
2006/02/20
In article <1140392909.403432.7587.nullmailer@x31.priv.netlab.jp>,
[#28348] Re: constant look up order in CVS HEAD
— Yukihiro Matsumoto <matz@...>
2006/02/20
まつもと ゆきひろです
[#28352] Re: constant look up order in CVS HEAD
— WATANABE Hirofumi <eban@...>
2006/02/20
わたなべです。
[#28360] ruby_1_8 broken? — "H.Yamamoto" <ocean@...2.ccsnet.ne.jp>
山本です。
7 messages
2006/02/21
[#28371] bcc32 make error on 1.9.0 — "Nebata" <tnebata@...>
ねばたです。
8 messages
2006/02/22
[#28372] Re: bcc32 make error on 1.9.0
— KIMURA Koichi <kimura.koichi@...>
2006/02/22
木村です。
[#28386] test/drb/drbtest.rb cause file missing error — arton <artonx@...>
artonです。
6 messages
2006/02/23
[#28389] Re: test/drb/drbtest.rb cause file missing error
— Yukihiro Matsumoto <matz@...>
2006/02/24
まつもと ゆきひろです
[#28396] ruby-1.8 cvs head and 64bit time_t — arton <artonx@...>
artonです。
7 messages
2006/02/26
[#28404] irb cannot parse /\^/ — "H.Yamamoto" <ocean@...2.ccsnet.ne.jp>
山本です。
8 messages
2006/02/27
[#28405] Re: irb cannot parse /\^/
— keiju@... (石塚圭樹)
2006/02/27
けいじゅ@いしつかです.
[ruby-dev:28336] Re: SEGV with zlib
From:
Tanaka Akira <akr@...17n.org>
Date:
2006-02-15 11:14:08 UTC
List:
ruby-dev #28336
In article <20060209111748.A8E247F0.ocean@m2.ccsnet.ne.jp>, H.Yamamoto <ocean@m2.ccsnet.ne.jp> writes: > http://www.nminoru.jp/~nminoru/programming/boehm-gc3.html > > に Boehm GC がどうしているのかが載っていました。なるほど、 > gc_mark と gc_sweep の間で、「マークされていない T_DATA で、 > mark 関数と free 関数の両方が定義されているもの」に対して > gc_mark_children を呼べば(自分自身はマークしない)ルートに > 当たる T_DATA だけマークが外れた状態になるので、順序付けでき > るんですね。(自分はマークしないというのは盲点でした) > > ただ、この方法にも問題があるらしく、それも記述されています。 まぁ、GC 側だけでどうにか解決しようとすればそんな感じになる でしょうし、そういう問題が残るでしょうね。 また、現在の Ruby のように、GC はそんな依存関係はいっさいケ アせずに拡張ライブラリ側がすべての責任を負うというのも、あま り幸せとはいえないわけです。 なので、狙いは GC と他のコードがもう少し協調してどうにかする、 というところです。 [ruby-dev:28322] でちょっと触れた、依存関係を明示的に登録さ せるというのもひとつのアイデアです。 また、他のアイデアとしては、オブジェクトが生成される場所を制 御するというものもあります。つまり、finalizer はヒープ内で順 番に起動されますから、先に finalizer が起動すべきオブジェク トを生成するときには、先に起動する場所にオブジェクトをアロケー トすればいいわけです。 例えば後者のアイデアについて考えると、利点は依存先が存在する finalizer つきのオブジェクトを生成しない限り追加コストが発生 しないということです。逆に欠点は依存先が生成時に決定され、変 化してはならないということです。 GzipWriter だと、出力先が IO であれば原理的にはその制約を満 たせそうです。現実にはバッファとして String を使っているので そこは変える必要がありますが。 また、bdb だと、env を db が参照しているという形についてはそ れでどうにかなりそうな気もします。 このふたつの事例だけで good enough といえるかというとそこは 難しいわけで、どういうのがいいのかなぁ、と結論には至っていな いんですが。 -- [田中 哲][たなか あきら][Tanaka Akira]