[#36058] Windows で Thread — rio-t@...
こんにちは、高石です。
14 messages
2002/10/01
[#36059] Re: Windows で Thread
— "U.Nakamura" <usa@...>
2002/10/01
こんにちは、なかむら(う)です。
[#36060] Re: Windows で Thread
— rio-t@...
2002/10/01
こんにちは、高石です。
[#36061] Re: Windows で Thread
— Tietew <tietew-ml-ruby-list@...>
2002/10/01
[#36069] 日本語に混じった URL を抜き出したい — keiichi matsunaga <ma2@...>
松永です。
26 messages
2002/10/02
[#36072] Re: 日本語に混じった URL を抜き出したい
— keiichi matsunaga <ma2@...>
2002/10/02
松永です。
[#36073] Re: 日本語に混じった URL を抜き出したい
— SAITO Shukaku <shukaku@...>
2002/10/02
At Wed, 2 Oct 2002 13:51:42 +0900,
[#36074] Re: 日本語に混じった URL を抜き出したい
— Tatsuhiko Miyagawa <miyagawa@...>
2002/10/02
宮川です。
[#36106] Ruby Weekly News mail archive on blade? — Tanaka Akira <akr@...17n.org>
ふと気がついたんですが、Ruby Weekly News は blade には archive されな
7 messages
2002/10/05
[#36114] RubyのXML対応に関する質問 — Shibukawa Yoshiki <yoshiki@...>
渋川です。
5 messages
2002/10/06
[#36117] 閉じたbinding — Takashi Tsugoh <tks@...>
こんばんは、Tsugohです。
7 messages
2002/10/06
[#36140] rindaで例外を通知する方法? — SAITO Shukaku <shukaku@...>
rindaとwebrickを使ってweb用アプリケーション(と言うのかな?)を作っていま
8 messages
2002/10/11
[#36161] gc_sweepでアボート — 原田 潤 <j-harada@...4u.or.jp>
原田と申します。
10 messages
2002/10/17
[#36178] utf-8 対応 nkf 拡張モジュールについて — たむらけんいち <sgs02516@...>
たむらです。御相談。
9 messages
2002/10/20
[#36186] csvweb.cgi error — TAKAHASHI Masayoshi <maki@...>
高橋征義です。
5 messages
2002/10/21
[#36188] Re: 日本語の字を書くGUIプログラム — Philip Mak <pmak0@...>
--- Philip Mak <pmak0@yahoo.com> wrote:
4 messages
2002/10/21
[#36192] RUBY_PLATFORM にはどんなものがある? — Take_tk <ggb03124@...>
たけ(tk)です
5 messages
2002/10/23
[#36205] [ANN] Ruby/Qte 0.2 — HIDAKA Takahiro <cv8t-hdk@...>
ひだかです。
10 messages
2002/10/27
[#36217] Re: Ruby/Qte 0.2
— SAITO Shukaku <shukaku@...>
2002/10/28
At Sun, 27 Oct 2002 14:03:33 +0900,
[#36226] Re: Ruby/Qte 0.2
— HIDAKA Takahiro <cv8t-hdk@...>
2002/10/29
ひだかです。
[ruby-list:36153] Re: rindaで例外を通知する方法?
From:
SAITO Shukaku <shukaku@...>
Date:
2002-10-15 05:09:33 UTC
List:
ruby-list #36153
先日のご助言について、もう少しお教えいただけますでしょうか?
At Fri, 11 Oct 2002 22:51:20 +0900,
m_seki@mva.biglobe.ne.jp wrote:
> 次の疑似コードでは、返信のタプルにエンジン側の処理スレッドを
> 渡しています。Thread#valueなので例外も受けとれると思います。
> また、TupleSpaceを介さずに結果をうけとるので、検索結果が
> 大きい時などには、効率がいいかもしれません。
> エンジン側
>
> while true
> tuple = ts.in([:find, nil, nil])
> thread = Thread.new(tuple[2]) { |arg| find_it(arg) }
> ts.out([:find_result, tuple[1], DRbObject.new(thread)])
> trhead.join
> end
この方法を試しておりまして、上記コード例の"thread.join"を省略しても良さ
そうに思えるのですが、ここでスレッドの完了を待つ必要というか、理由はどの
ようなものでしょうか?
GCの関係かと思いましたが、TupleSpaceへ投入したスレッドは参照され続けてい
ることになって、要求側がタプルを取り出すまではGCの対象になりませんよね?
生成したスレッドの終了を待たずに次のタプルを取り出すことで、多数のスレッ
ドを生成してしまわないようにする仕組みかとも思いましたが、それでは多数の
処理要求を受けた際に1つずつ処理することになるような...。そのような負荷の
抑制が狙いでしょうか?
また、find_it内で例外が発生する場合に備えて次のようにする必要があると理
解していますが、正しいでしょうか?
begin
thread.join
rescue
end
短いコードを動かしつつ試しておりますが、誤解しているような気がして不安な
のです。よろしければご指摘をお願いします。 >皆様
///// ------------------------------------------------------------------
-O-O- 斉藤 秀格 (SAITO Shukaku) @ PUGH (Palm Users Group in Hokkaido)
_ mailto:shukaku@sai10.nu (ぱふ) http://www.pugh.palm-j.com/