[#6219] Ruby連載 第4話 — matz@... (Yukihiro Matsumoto)

まつもと ゆきひろです

32 messages 1998/02/04
[#6221] Re: Ruby連載 第4話 — Shin-ichiro HARA <sinara@...> 1998/02/04

原です。

[#6224] Re: Ruby連載 第4話 — Yasunari Momoi <conan@...> 1998/02/04

ももちゃん@あるもにこすです.

[#6225] Re: Ruby連載 第4話 — matz@... (Yukihiro Matsumoto) 1998/02/04

まつもと ゆきひろです

[#6249] Re: i++ — 助田 雅紀 <masaki.suketa@...>

助田です。

33 messages 1998/02/04
[#6252] Re: i++ — gotoken@... (GOTO Kentaro) 1998/02/05

ことけんです

[#6255] Re: i++ — matz@... (Yukihiro Matsumoto) 1998/02/05

まつもと ゆきひろです

[#6260] Re: i++ — Yuji Shigehiro <sigehiro@...> 1998/02/05

しげひろです.

[#6314] RE: ruby's design policy (Re: I'd like to subscr ibe this ML) — 助田 雅紀 <masaki.suketa@...>

オブジェクト指向周辺をぶらぶらしている助田です。

11 messages 1998/02/06

[#6333] ruby 流に添削して下さい — nkon@...2.3web.ne.jp

13 messages 1998/02/07
[#6335] Re: ruby 流に添削して下さい — OZAWA Sakuro <crouton@...> 1998/02/07

さくです.

[#6372] ruby 1.1b7 released — matz@... (Yukihiro Matsumoto)

まつもと ゆきひろです

24 messages 1998/02/10
[#6402] parsedate (Re: ruby 1.1b7 released) — WATANABE Hirofumi <watanabe@...> 1998/02/13

わたなべです.

[#6405] Re: parsedate (Re: ruby 1.1b7 released) — Tadayoshi Funaba <tadf@...> 1998/02/13

ふなばです。

[#6407] Re: parsedate (Re: ruby 1.1b7 released) — matz@... (Yukihiro Matsumoto) 1998/02/13

まつもと ゆきひろです

[#6373] call for scripts — matz@... (Yukihiro Matsumoto)

まつもと ゆきひろです

133 messages 1998/02/10
[#6414] Re: call for scripts — Terutuoshi Kaneshiro <k-teru@...06.odn.ne.jp> 1998/02/14

金城です.

[#6428] Re: call for scripts — matz@... (Yukihiro Matsumoto) 1998/02/16

まつもと ゆきひろです

[#6448] Re: call for scripts — Terutuoshi Kaneshiro <k-teru@...06.odn.ne.jp> 1998/02/16

金城です.

[#6452] Re: call for scripts — matz@... (Yukihiro Matsumoto) 1998/02/17

まつもと ゆきひろです

[#6481] Re: call for scripts — Kikutani Makoto <kikutani@...> 1998/02/17

きくたに@ぷ〜たろ〜です。

[#6483] Re: call for scripts — OZAWA Sakuro <crouton@...> 1998/02/17

さくです.

[#6495] Re: call for scripts — WATANABE Hirofumi <watanabe@...> 1998/02/18

わたなべです.

[#6416] Re: call for scripts — shugo@... (Shugo Maeda) 1998/02/14

前田です。

[#6417] rgrep (Re: call for scripts) — shugo@... (Shugo Maeda) 1998/02/15

前田です。

[#6423] Re: rgrep (Re: call for scripts) — matz@... (Yukihiro Matsumoto) 1998/02/16

まつもと ゆきひろです

[#6612] Re: call for scripts — Tadayoshi Funaba <tadf@...> 1998/02/21

ふなばです。

[#6582] File::Separator on cygwin — OZAWA Sakuro <ozawa@...>

小澤さくです。

19 messages 1998/02/20
[#6583] Re: File::Separator on cygwin — WATANABE Hirofumi <watanabe@...> 1998/02/20

わたなべです.

[#6586] Re: File::Separator on cygwin — OZAWA Sakuro <ozawa@...> 1998/02/20

小澤さくです。

[#6591] ruby 1.1b8 released — matz@... (Yukihiro Matsumoto)

まつもと ゆきひろです

32 messages 1998/02/20
[#6620] rbc.rb and binding — shugo@... (Shugo Maeda) 1998/02/22

前田です。

[#6629] Re: rbc.rb and binding — keiju@... (石塚圭樹 ) 1998/02/23

けいじゅ@日本ラショナルソフトウェアです.

[#6643] Re: rbc.rb and binding — shugo@... (Shugo Maeda) 1998/02/23

前田です。

[#6649] Re: rbc.rb and binding — keiju@... (石塚圭樹 ) 1998/02/23

けいじゅ@日本ラショナルソフトウェアです.

[#6650] Re: rbc.rb and binding — matz@... (Yukihiro Matsumoto) 1998/02/23

まつもと ゆきひろです

[#6667] JRI 0.5 worked (was Re: rbc.rb and binding) — OZAWA Sakuro <crouton@...> 1998/02/23

さくです.

[#6687] Re: JRI 0.5 worked (was Re: rbc.rb and binding) — shugo@... (Shugo Maeda) 1998/02/24

前田です。

[#6712] JRI and JDBC — OZAWA Sakuro <ozawa@...> 1998/02/24

小澤さくです。

[#6635] hello — WATANABE Tetsuya <tetsu@...>

渡辺哲也と申します。

15 messages 1998/02/23

[#6706] Re: Counter class — toyofuku@...

豊福@パパイヤです。

12 messages 1998/02/24

[#6735] Mutex/ConditionVariable/Queue — shugo@... (Shugo Maeda)

前田です。

27 messages 1998/02/24
[#6746] Re: Mutex/ConditionVariable/Queue — keiju@... (石塚圭樹 ) 1998/02/25

けいじゅ@日本ラショナルソフトウェアです.

[#6747] Re: Mutex/ConditionVariable/Queue — shugo@... (Shugo Maeda) 1998/02/25

前田です。

[#6752] Re: Mutex/ConditionVariable/Queue — senda@... 1998/02/25

From: shugo@po.aianet.ne.jp (Shugo Maeda)

[#6754] Re: Mutex/ConditionVariable/Queue — shugo@... (Shugo Maeda) 1998/02/25

前田です。

[#6756] Re: Mutex/ConditionVariable/Queue — senda@... 1998/02/25

From: shugo@po.aianet.ne.jp (Shugo Maeda)

[#6786] Re: Mutex/ConditionVariable/Queue — senda@...

From: shugo@po.aianet.ne.jp (Shugo Maeda)

33 messages 1998/02/26
[#6791] Re: Mutex/ConditionVariable/Queue — shugo@... (Shugo Maeda) 1998/02/26

前田です。

[#6794] Re: Mutex/ConditionVariable/Queue — shugo@... (Shugo Maeda) 1998/02/26

前田です。

[#6796] Re: Mutex/ConditionVariable/Queue — keiju@... (石塚圭樹 ) 1998/02/26

けいじゅ@日本ラショナルソフトウェアです.

[ruby-list:6756] Re: Mutex/ConditionVariable/Queue

From: senda@...
Date: 1998-02-25 08:18:51 UTC
List: ruby-list #6756
From: shugo@po.aianet.ne.jp (Shugo Maeda)
Subject: [ruby-list:6754] Re: Mutex/ConditionVariable/Queue
Date: Wed, 25 Feb 1998 15:44:47 +0900
Message-ID: <199802250616.GAA01595@soleil.localnet.or.jp>

shugo> 前田です。
shugo> 
shugo> # Reply-Toが設定されているようですが、意図されているのでしょうか?

すいません。.emacsを編集したあとemacsを立ち上げ直していませんでした。:-(

shugo> In message "[ruby-list:6752] Re: Mutex/ConditionVariable/Queue"
shugo> senda@ic.rdc.ricoh.co.jp <senda@ic.rdc.ricoh.co.jp> wrote:
shugo> 
shugo> |shugo> |>今JavaでMutexとConditionVariableを作っているのですが
shugo> |
shugo> |JavaでConditionVariableがいる理由がわからないのですが。
shugo> |
shugo> |# つくってみたかっただけなのかな :-)
shugo> 
shugo> いえ、違います:-)
shugo> 
shugo> |Javaのsynchronized宣言
shugo> /java.lang.object.wait()/java.lang.object.notify() 
shugo> |はこのConditionVariableを隠蔽するための機構です(モニターと呼ばれる)。
shugo> 
shugo> これは知っています。
shugo> # というかMutex/ConditionVariableはJavaのモニタ機構を使って実装して
shugo> # います。

そうだろうと想像していました。

shugo> fj.comp.parallelで話題になったので詳しくはそちらを見ていただけると
shugo> ありがたいのですが、

久しぶりにnewsをのぞいてみて文脈は理解しました。

shugo> Javaのsynchronized構文ではブロック構造になるの
shugo> で任意のスコープで排他制御を行えません。

これはあんまり強い制限ではないとはおもいますが(排他制御を行う部分を
synchronized methodにしてやればよい)、

shugo> また、Javaでは条件変数がリソースにつき一個ずつしか持てないことに
shugo> なるのですが、条件変数は各リソースではなく、条件の待ち方の個数に
shugo> 対応します。
shugo> つまりリソースは一個でも条件変数が複数という場合がありうるのですが、
shugo> JavaだとnotifyAllですべてのスレッドを起こさないといけないことに
shugo> なります。
shugo> 

これは何回か思ったことがあります。
元々のHoareのモニタ機構は条件変数が複数宣言できるはずです。

shugo> というわけでMutex/ConditionVariableが欲しい、という話になって
shugo> 実装してみたわけです。
shugo> 

ただ、モニタ機構は素人にとっては使いやすい機構だといえます。個人的経験では
排他制御の8ー9割は単にmutex(synchronized)を書くだけだし、条件変数を使う
場合でもそんなに複雑なことをしたおぼえはありません(そんなことはないという
人は当然いるとは思いますが)。

ということでRubyに話をもどすと

Mutex.shinchronize {...} と前田さんのConditionVariableの組合わせはインター
フェースとしては悪くない気がします。

ただこいつらがプリミティブでないとするとスレッドのスケジューリングはどうな
っているのかなという疑問がでてくるのですが。 :-)

# threadの実装は良く知らないのですが、signal()のあとどこのthreadに制御を
# 移すかがキモらしい。

						S.Senda

In This Thread