質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.50%
Ruby

Rubyはプログラミング言語のひとつで、オープンソース、オブジェクト指向のプログラミング開発に対応しています。

Q&A

解決済

2回答

371閲覧

rubyのメソッドの並列処理について

aws

総合スコア48

Ruby

Rubyはプログラミング言語のひとつで、オープンソース、オブジェクト指向のプログラミング開発に対応しています。

0グッド

0クリップ

投稿2018/02/15 15:55

rubyのメソッドを並列で動かしたいと考えているのですが以下の様な書き方で問題御座いませんか?

メソッド例として

def test11 puts 11 sleep(1) end def test22 puts 22 sleep(3) end def test33 puts 33 sleep(10) end def test44 puts 44 sleep(30) end

現在の動かし方

Thread.start { loop do test11 end } Thread.start { loop do test22 end } Thread.start { loop do test33 end } loop do test44 end

実行してみた結果は並列で動いている様に見えるのですが、こんな書き方でいいのかなーと思いまして。
検索で"ruby 並列処理"などで調べると"Parallel" GEMを利用した方法が出てくるのですが値を並列で処理する方法は出てくるのですがメソッドを並列で処理の方法は分かりませんでした。

もっと簡単に高速で並列して処理する方法などあれば教えて頂ければ幸いです。
宜しくお願いします。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答2

0

ベストアンサー

ふつうのRuby(CRuby)の場合、スレッドを分けてもGiant VM Lockがあるので、(I/O待ちを除けば)同時に1スレッドしか実行されません

プロセスごと分ける、あるいはJavaのスレッドをそのまま使うので完全なマルチスレッドになっているJRubyを使う、などの必要があります(parallelは、内部的に複数プロセスを立ち上げています)。

投稿2018/02/16 00:17

編集2018/02/16 00:23
maisumakun

総合スコア145121

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

aws

2018/02/16 14:18

ご回答有難う御座います。 >同時に1スレッドしか実行されません なるほど。勝手な思い込みでThread.startで動かせば複数のスレッドで同時処理されているのかと考えていました。 Ruby(CRuby)でプログラムを動かしたいと考えているのでparallelを利用してみたいと思います。
guest

0

参考情報

  • Ruby 2.5.0 リファレンスマニュアル > ライブラリ一覧 > 組み込みライブラリ > Threadクラス

https://docs.ruby-lang.org/ja/latest/class/Thread.html

  • Rubyで基礎的なマルチスレッドプログラミングをするためのサンプル

http://blog.codebook-10000.com/entry/20130804/1375631808

  • 【Ruby】Parallelで並列処理

http://llcc.hatenablog.com/entry/2018/01/07/124209

投稿2018/02/15 17:34

katoy

総合スコア22324

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

aws

2018/02/16 13:58

参考情報有難う御座います。確認させて頂きます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.50%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問