ruby-dev (Japanese) list archive (unofficial mirror)
 help / color / mirror / Atom feed
* [ruby-dev:44546] [Ruby 1.9 - Bug #5368][Open] ensure節でsleepするようなThreadがあるとインタプリタが終了しない
@ 2011-09-26  4:51 Masaki Matsushita
  2011-09-26  5:24 ` [ruby-dev:44547] " SASADA Koichi
                   ` (15 more replies)
  0 siblings, 16 replies; 22+ messages in thread
From: Masaki Matsushita @ 2011-09-26  4:51 UTC (permalink / raw)
  To: ruby developers list


Issue #5368 has been reported by Masaki Matsushita.

----------------------------------------
Bug #5368: ensure節でsleepするようなThreadがあるとインタプリタが終了しない
http://redmine.ruby-lang.org/issues/5368

Author: Masaki Matsushita
Status: Open
Priority: Normal
Assignee: 
Category: core
Target version: 1.9.x
ruby -v: ruby 1.9.4dev (2011-09-26 trunk 33338) [x86_64-linux]


=begin
次のコードを実行するとCPU使用率が跳ね上がった状態になりインタプリタが終了しません。

 Thread.new do
   begin
     sleep
   ensure
     sleep
   end
 end

現在のrb_thread_terminate_allでは最初に1回だけ生きているスレッドに対してterminate_iを実行していますが、ensure節でsleepするようなThreadがあると、そのThreadは寝たままになってしまいwhile(!rb_thread_alone())が無限ループになってしまいます。

while(!rb_thread_alone())の毎回のループでカレントスレッドがメインスレッドであった場合に、生きているスレッドに対してterminate_iを実行するようなpatchを書いたところ、このバグは再現しなくなりました。
patchを添付します。patchの適用後もtest-allをパスします。
=end


-- 
http://redmine.ruby-lang.org

^ permalink raw reply	[flat|nested] 22+ messages in thread

end of thread, other threads:[~2018-04-06  5:28 UTC | newest]

Thread overview: 22+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2011-09-26  4:51 [ruby-dev:44546] [Ruby 1.9 - Bug #5368][Open] ensure節でsleepするようなThreadがあるとインタプリタが終了しない Masaki Matsushita
2011-09-26  5:24 ` [ruby-dev:44547] " SASADA Koichi
2011-09-26 13:40   ` [ruby-dev:44550] " KOSAKI Motohiro
2011-09-26 14:03   ` [ruby-dev:44551] " m_takao
2011-09-26 14:52     ` [ruby-dev:44552] " SASADA Koichi
2011-09-29 11:20       ` [ruby-dev:44561] " Nobuyoshi Nakada
2011-09-29 12:14         ` [ruby-dev:44563] " KOSAKI Motohiro
2011-09-29 16:29 ` [ruby-dev:44564] [Ruby 1.9 - Bug #5368] ensure節でsleepするようなThreadがあるとインタプリタが終了しない Shyouhei Urabe
2012-03-11  7:06 ` [ruby-dev:45327] [ruby-trunk " Koichi Sasada
2012-11-26  0:26 ` [ruby-dev:46622] " ko1 (Koichi Sasada)
2012-11-26  3:27 ` [ruby-dev:46626] " kosaki (Motohiro KOSAKI)
2012-11-26 13:40 ` [ruby-dev:46631] " kosaki (Motohiro KOSAKI)
2012-11-26 13:59 ` [ruby-dev:46632] [ruby-trunk - Bug #5368][Assigned] ensure節でsleepするようなThreadがあるとインタプリタが終了しない kosaki (Motohiro KOSAKI)
2012-11-26 16:15 ` [ruby-dev:46634] [ruby-trunk - Bug #5368] ensure節でsleepするようなThreadがあるとインタプリタが終了しない kosaki (Motohiro KOSAKI)
2012-11-26 16:26 ` [ruby-dev:46635] " kosaki (Motohiro KOSAKI)
2012-11-26 20:09 ` [ruby-dev:46636] " tarui (Masaya Tarui)
2012-11-26 23:13 ` [ruby-dev:46637] " kosaki (Motohiro KOSAKI)
2012-11-26 23:16 ` [ruby-dev:46638] " kosaki (Motohiro KOSAKI)
2012-11-27 17:08 ` [ruby-dev:46643] " kosaki (Motohiro KOSAKI)
2013-02-17  6:19 ` [ruby-dev:47006] " ko1 (Koichi Sasada)
2014-01-30  6:16 ` [ruby-dev:47929] " shibata.hiroshi
2018-04-06  5:28 ` [ruby-dev:50521] [Ruby trunk Bug#5368] ensure節でsleepするようなThreadがあるとインタプリタが終了しない mame

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).