[#29469] エラーを捕まえたいのですが ... — Sakae Kobayashi <sakae@...>

困った時に出てくる、小林榮です。

12 messages 2001/05/01

[#29490] Re: [ruby-talk:14555] Ruby as a Mac OS/X scripting language — maili31s@... (SugHimsi == SUGIHARA Hiroshi)

すぎむし速報。↓だそうです。

12 messages 2001/05/02

[#29524] tr range? — kiri@...

桐山です。

17 messages 2001/05/06
[#29526] Re: tr range? — Koji Arai <JCA02266@...> 2001/05/06

新井です。

[#29644] rwiki.rb でエラー — norio goto <goto@...>

お世話になります、後藤@横河工事です。

18 messages 2001/05/14
[#29645] Re: rwiki.rb でエラー — m_seki@... 2001/05/14

[#29646] Re: rwiki.rb でエラー — norio goto <goto@...> 2001/05/14

後藤@横河工事です。

[#29675] with(obj){ } が欲しい。 — Take_tk <ggb03124@...>

例によって、ワタシ好みののりクエストですみません。

24 messages 2001/05/15
[#29694] Re: with(obj){ } が欲しい。 — "K.Kosako" <kosako@...> 2001/05/17

Take_tkさんの<20010515205133.DFBA.GGB03124@nifty.ne.jp>から

[#29707] OBJECT DAY2001 — "K.Kosako" <kosako@...>

OBJECT DAY2001から帰ってきました。

71 messages 2001/05/18
[#29712] Re: OBJECT DAY2001 — matz@... (Yukihiro Matsumoto) 2001/05/18

まつもと ゆきひろです

[#29719] Re: OBJECT DAY2001 — WATANABE Tetsuya <tetsu@...> 2001/05/21

渡辺哲也です。

[#29731] YARPC 19101 (Re: OBJECT DAY2001) — TAKAHASHI Masayoshi <maki@...> 2001/05/21

YARPC関連で動いてお騒がせしている(_o_)高橋征義です。

[#29792] Re: YARPC 19101 — akira yamada / やまだあきら <akira@...> 2001/05/27

[#29794] Re: YARPC 19101 — Minero Aoki <aamine@...> 2001/05/27

あおきです。

[#29803] Re: YARPC 19101 — Hiroshi IGARASHI <iga@...> 2001/05/27

いがらしです。

[#29721] Cygwin で Ruby をコンパイルするとエラーがでます。 — "Inoue" <inoue@...>

はじめまして、最近Rubyをはじめました井上と申します。

10 messages 2001/05/21

[#29788] marshaled time format differ — IWATSUKI Hiroyuki <don@...>

岩月と申します。

19 messages 2001/05/25
[#29789] Re: marshaled time format differ — matz@... (Yukihiro Matsumoto) 2001/05/25

まつもと ゆきひろです

[#29790] Re: marshaled time format differ — IWATSUKI Hiroyuki <don@...> 2001/05/26

岩月と申します。

[#29823] Re: marshaled time format differ — IWATSUKI Hiroyuki <don@...> 2001/05/27

岩月と申します。

[#29853] "" で行われる展開を eval 無しで… — ABE Shigeru <shiger-a@...>

 みなさま、はじめまして。阿部といいます。

17 messages 2001/05/28
[#29854] Re: "" で行われる展開を eval 無しで… — rubikitch <rubikitch@...> 2001/05/28

From: ABE Shigeru <shiger-a@nifty.com>

[#29941] Ruby ライセンスについて — matz@... (Yukihiro Matsumoto)

まつもと ゆきひろです

38 messages 2001/05/31
[#29942] Re: Ruby ライセンスについて — Takahiro Kambe <taca@...> 2001/05/31

In message <991297854.779223.23013.nullmailer@ev.netlab.zetabits.com>

[#29944] Re: Ruby ライセンスについて — "Akinori MUSHA" <knu@...> 2001/05/31

At Thu, 31 May 2001 18:00:18 +0900,

[ruby-list:29584] [BUG?] Thread の終了時に Thread.critical が解除されない。

From: "Okada Jun" <yun@...>
Date: 2001-05-07 18:28:12 UTC
List: ruby-list #29584
岡田です。

スレッドの同時起動数を制限する目的で、次のようなコードを書きました。

#!/usr/bin/env ruby

# スレッドの状態を1秒毎に監視
Thread.start do
  loop do
    puts Thread.list.size.to_s, Thread.main.inspect
    sleep 1
  end
end

# 最大同時起動数100でスレッドを連続して起動
500.times do
  Thread.start do
    sleep(1)
    Thread.critical = true
    Thread.main.wakeup
#    Thread.critical = false
  end
  Thread.critical = true
  Thread.stop if Thread.list.size >=102
  Thread.critical = false
end

# 全てのスレッドの終了を待つ
loop do
  Thread.critical = true
  if Thread.list.size <= 2
    Thread.critical = false
    break
  end
  Thread.stop
end


問題となるのは、threadの最後にコメントアウトしているThread.critical = falseの部分です。
このようにコメントアウトしたままだと、critical状態が解除されずに、スクリプトは終了
しなくなってしまいます。

マニュアルの記述によれば、

> critical = yes_no 
> 真である場合,スレッドの切替えを行いません. カレントスレッドが停止した場合やシグナ
> ルに割り込まれた場合には,自動的に false になります. 

とあるので、スレッドの終了時に自動的に解除されるものと思っていたのですが、
このスクリプトの形で期待通りに動作しないのは内部的にどういう動作をして
いるのでしょうか?

ちなみにこの動作を確認したのは

Intel Pentium III 700MHz (FC-PGA)
512MB (PC100-CL2 128MB x 4)
FreeBSD 4.1.1-STABLE-20001022-JPSNAP #2
ruby 1.6.3 (2001-03-19) [i386-freebsdelf4.1.1]

という環境です。

--
ゆん(岡田 潤)
yun@nekome.net
http://www.nekome.net/

In This Thread

Prev Next