亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > Ruby > 正文

Ruby多線程編程 新手教程

2020-02-24 15:40:18
字體:
來源:轉載
供稿:網友

  下面是小編給大家分享的一篇ruby.html" target="_blank">Ruby多線程編程 新手教程,感興趣的朋友跟小編一起來了解一下吧!

  傳統程序有一個單獨的線程執行,包含該程序的語句或指令順序執行直到程序終止。

  一個多線程的程序有多個線程的執行。在每個線程是按順序執行的,但是在多核CPU機器上線程可能并行地執行。例如,通常情況下在單一CPU的機器,多個線程實際上不是并行執行的,而是模擬并行交叉的線程的執行。

  Ruby的可以使用 Thread 類很容易地編寫多線程程序。 Ruby線程是一個輕量級的和高效的在代碼中實現并行性。

  創建Ruby線程:

  要啟動一個新線程,關聯一個塊通過調用Thread.new。將創建一個新的線程執行的代碼塊,原始線程將立即從Thread.new返回并繼續執行下一個語句:

  # Thread #1 is running here

  Thread.new {

  # Thread #2 runs this code

  }

  # Thread #1 runs this code

  例如:

  這里是一個例子說明,我們如何能夠利用多線程的Ruby的程序。

  #!/usr/bin/ruby

  def func1

  i=0

  while i

  puts "func1 at: #{Time.now}"

  sleep(2)

  i=i+1

  end

  end

  def func2

  j=0

  while j

  puts "func2 at: #{Time.now}"

  sleep(1)

  j=j+1

  end

  end

  puts "Started At #{Time.now}"

  t1=Thread.new{func1()}

  t2=Thread.new{func2()}

  t1.join

  t2.join

  puts "End at #{Time.now}"

  這將產生以下結果:

  Started At Wed May 14 08:21:54 -0700 2008

  func1 at: Wed May 14 08:21:54 -0700 2008

  func2 at: Wed May 14 08:21:54 -0700 2008

  func2 at: Wed May 14 08:21:55 -0700 2008

  func1 at: Wed May 14 08:21:56 -0700 2008

  func2 at: Wed May 14 08:21:56 -0700 2008

  func1 at: Wed May 14 08:21:58 -0700 2008

  End at Wed May 14 08:22:00 -0700 2008

  線程的生命周期:

  創建一個新的線程用 Thread.new。也可以使用了同義詞用 Thread.Start 和 Thread.fork。

  沒有必要啟動一個線程在它被創建后,它會自動開始運行時,CPU 資源成為可用。

  Thread 類定義了一些方法來查詢和處理的線程在運行時。運行一個線程塊中的代碼調用Thread.new,然后它停止運行。

  該塊中的最后一個表達式的值是線程的值,可以通過調用 Thread對象值的方法。如果線程運行完成,則該值為線程的返回值。否則,該值方法會阻塞不會返回,直到該線程已完成。

  類方法Thread.current返回代表當前線程的 Thread對象。這允許線程操縱自己。類方法 Thread.main返回線程對象代表主線程,thread.this初始線程開始執行Ruby程序開始時。

  可以等待一個特定的線程通過調用該線程的Thread.Join方法來完成。調用線程將被阻塞,直到給定線程完成。

  線程和異常:

  如果在主線程中引發一個異常,并沒有任何地方處理,Ruby解釋器打印一條消息并退出。在主線程以外的其他線程,未處理的異常導致線程停止運行。

  如果線程 t 退出,因為未處理的異常,而另一個線程調用t.join或t.value,那么所發生的異常在 t 中提出的線程 s。

  如果 Thread.abort_on_exception 為 false,默認情況下,出現未處理的異常只是殺死當前線程和所有其余的繼續運行。

  如果想在任何線程中的任何未處理的異常導致解釋退出中,設置類方法Thread.abort_on_exception 為 true。

  t = Thread.new { ... }

  t.abort_on_exception = true

  線程變量:

  一個線程可以正常訪問是在范圍內的任何變量的線程被創建時。一個線程塊的局部變量是線程的局部,而不是共享。

  Thread類提供一個特殊的功能,允許通過名稱來創建和存取線程局部變量。只需把線程對象,如果它是一個Hash,寫入元素使用[] =和讀取他們帶回使用[]。

  在這個例子中,每個線程記錄計數變量的當前值與該鍵mycount的一個threadlocal變量。

  #!/usr/bin/ruby

  count = 0

  arr = []

  10.times do |i|

  arr[i] = Thread.new {

  sleep(rand(0)/10.0)

  Thread.current["mycount"] = count

  count += 1

  }

  end

  arr.each {|t| t.join; print t["mycount"], ", " }

  puts "count = #{count}"

  這將產生下面的結果:

  8, 0, 3, 7, 2, 1, 6, 5, 4, 9, count = 10

  主線程等待子線程完成,然后打印出每個捕獲count的值。

  線程優先級:

  影響線程調度的第一因素,是線程的優先級:高優先級線程之前計劃的低優先級的線程。更確切地說,一個線程將只獲得CPU時間,如果沒有更高優先級的線程等待運行。

  可以設置和查詢一個Ruby線程對象的優先級=和優先級的優先級。新創建的線程開始在相同的優先級的線程創建它。啟動主線程優先級為0。

  沒有任何方法設置線程優先級在開始運行前。然而,一個線程可以提高或降低自己的優先級的第一次操作。

  線程排斥:

  如果兩個線程共享訪問相同的數據,至少有一個線程修改數據,你必須要特別小心,以確保任何線程都不能看到數據處于不一致的狀態。這稱為線程排除。

  Mutex類是一些共享資源的互斥訪問,實現了一個簡單的信號鎖定。即,只有一個線程可持有的鎖在給定時間。其他線程可能選擇排隊等候的鎖變得可用,或者可以簡單地選擇立即得到錯誤,表示鎖定不可用。

  通過將所有訪問共享數據的互斥體的控制下,我們確保一致性和原子操作。我們的嘗試例子,第一個無需mutax,第二個使用mutax:

  無需Mutax的例子:

  #!/usr/bin/ruby

  require 'thread'

  count1 = count2 = 0

  difference = 0

  counter = Thread.new do

  loop do

  count1 += 1

  count2 += 1

  end

  end

  spy = Thread.new do

  loop do

  difference += (count1 - count2).abs

  end

  end

  sleep 1

  puts "count1 : #{count1}"

  puts "count2 : #{count2}"

  puts "difference : #{difference}"

  這將產生以下結果:

  count1 : 1583766

  count2 : 1583766

  difference : 637992

  #!/usr/bin/ruby

  require 'thread'

  mutex = Mutex.new

  count1 = count2 = 0

  difference = 0

  counter = Thread.new do

  loop do

  mutex.synchronize do

  count1 += 1

  count2 += 1

  end

  end

  end

  spy = Thread.new do

  loop do

  mutex.synchronize do

  difference += (count1 - count2).abs

  end

  end

  end

  sleep 1

  mutex.lock

  puts "count1 : #{count1}"

  puts "count2 : #{count2}"

  puts "difference : #{difference}"

  這將產生以下結果:

  count1 : 696591

  count2 : 696591

  difference : 0

  處理死鎖:

  當我們開始使用互斥對象的線程排除,我們必須小心地避免死鎖。死鎖的情況發生時,所有線程正在等待獲取另一個線程持有的資源。因為所有的線程被阻塞,他們不能釋放其所持有的鎖。因為他們可以不釋放鎖,其它線程不能獲得這些鎖。

  一個條件變量僅僅是一個信號,與資源相關聯,并用于特定互斥鎖的保護范圍內的。當需要一個資源不可用,等待一個條件變量。這一行動釋放相應的互斥鎖。當一些其他線程發送信號的資源是可用的,原來的線程來等待,并同時恢復上的鎖臨界區。

  例子:

  #!/usr/bin/ruby

  require 'thread'

  mutex = Mutex.new

  cv = ConditionVariable.new

  a = Thread.new {

  mutex.synchronize {

  puts "A: I have critical section, but will wait for cv"

  cv.wait(mutex)

  puts "A: I have critical section again! I rule!"

  }

  }

  puts "(Later, back at the ranch...)"

  b = Thread.new {

  mutex.synchronize {

  puts "B: Now I am critical, but am done with cv"

  cv.signal

  puts "B: I am still critical, finishing up"

  }

  }

  a.join

  b.join

  這將產生以下結果:

  A: I have critical section, but will wait for cv

  (Later, back at the ranch...)

  B: Now I am critical, but am done with cv

  B: I am still critical, finishing up

  A: I have critical section again! I rule!

  線程狀態:

  有五種可能的返回值對應于下表中所示的5個可能的狀態。該的狀態方法返回的線程狀態。

2015513111419712.jpg (585×209)

  Thread類的方法:

  Thread類提供以下方法,它們適用程序的所有線程。這些方法它們使用Thread類的名稱來調用,如下所示:

  Thread.abort_on_exception = true

  這里是所有類方法的完整列表:

2015513111447500.jpg (553×637)

2015513111506005.jpg (552×419)

  線程實例方法:

  這些方法是適用于一個線程的一個實例。這些方法將被調用,使用一個線程的一個實例如下:

  #!/usr/bin/ruby

  thr = Thread.new do # Calling a class method new

  puts "In second thread"

  raise "Raise exception"

  end

  thr.join # Calling an instance method join

  這里是所有實例方法的完整列表:

2015513111530766.jpg (552×724)

2015513111548091.jpg (547×503)

  以上就是Ruby多線程編程 新手教程了,想必都了解了吧,更多相關內容請繼續關注武林技術頻道。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美日韩一区二区三区在线免费观看| 欧美在线欧美在线| 亚洲欧美日韩中文在线| 亚洲精品一区av在线播放| 一本大道亚洲视频| 久久国产精品久久久| 久久精品国产综合| 久久成人18免费网站| 精品香蕉在线观看视频一| 91欧美精品成人综合在线观看| 丝袜亚洲另类欧美重口| 亚洲护士老师的毛茸茸最新章节| 亚洲天堂免费在线| 日韩av中文字幕在线| 国内精品久久久久久中文字幕| 91久久久国产精品| 日韩av片免费在线观看| 91在线观看免费网站| 亚洲一区二区少妇| 成人欧美一区二区三区在线湿哒哒| yw.139尤物在线精品视频| 亚洲第一av网| 精品久久久久久久大神国产| 久久久久久久香蕉网| 国内揄拍国内精品少妇国语| 国产精品一区二区久久久| 久久在线视频在线| 91视频免费网站| 国产精品美女无圣光视频| 97视频在线观看视频免费视频| 国产一区二区三区久久精品| 国产日韩中文字幕在线| 亚洲视频国产视频| 91精品在线一区| 欧美日韩国产精品| 欧美日韩在线第一页| 亚洲欧美精品suv| 久久激情视频免费观看| 亚洲免费伊人电影在线观看av| 欧美成aaa人片免费看| 九九热精品视频国产| 欧美亚洲国产精品| 精品国产乱码久久久久酒店| 中文字幕亚洲精品| 国产午夜精品全部视频播放| 国语自产精品视频在免费| 日韩免费在线看| 国产精品久久久91| 国产香蕉精品视频一区二区三区| 国产啪精品视频| www.日韩不卡电影av| 日韩av成人在线观看| 福利视频一区二区| 日韩免费在线观看视频| 国产成人精品网站| 国产精品久久久久久久久| 91精品啪在线观看麻豆免费| 国产精品手机播放| 亚洲欧美成人一区二区在线电影| 亚洲午夜未删减在线观看| 福利一区福利二区微拍刺激| 国产精品视频26uuu| 国产视频精品久久久| 456国产精品| 国产视频在线一区二区| 伦伦影院午夜日韩欧美限制| 精品中文字幕久久久久久| 欧美成人免费全部观看天天性色| 亚洲天天在线日亚洲洲精| 日本一区二区在线播放| 欧美性猛交xxxx乱大交蜜桃| 亚洲最大福利视频网| 日韩精品免费综合视频在线播放| 国产精品欧美在线| 久久久国产成人精品| 日韩中文字幕在线看| 91中文在线视频| 久久免费视频观看| 欧美成人精品一区| 欧美精品性视频| 亚洲第一区第二区| 日韩av有码在线| 国产精品久久久久一区二区| 九九精品视频在线| 日韩国产精品一区| 国产精品色午夜在线观看| 久久91超碰青草是什么| 日韩av影院在线观看| 亚洲人成电影在线观看天堂色| 久久男人的天堂| 国产精品入口尤物| 亚洲淫片在线视频| 国产精品福利网| 成人精品在线视频| 亚洲欧洲国产精品| 亚洲经典中文字幕| 在线性视频日韩欧美| 91精品久久久久久久久久久| 精品成人国产在线观看男人呻吟| 久久久久久亚洲| 亚洲视频电影图片偷拍一区| 日韩福利视频在线观看| 欧美大片免费看| 日韩中文字幕在线免费观看| 精品久久久国产精品999| 日韩美女在线看| 欧美视频免费在线| 欧美性受xxxx黑人猛交| 国产成+人+综合+亚洲欧美丁香花| 一区二区中文字幕| 91精品国产一区| 亚洲综合av影视| 精品少妇v888av| 成人国产精品日本在线| 精品国内自产拍在线观看| 欧美午夜www高清视频| 国产日韩精品综合网站| 91av在线不卡| 欧美日韩在线视频一区二区| 亚洲成人免费在线视频| 91成人免费观看网站| 日韩av最新在线| 色综合久久88色综合天天看泰| 欧美在线视频免费播放| 亚洲一区二区久久| 欧美日韩午夜激情| 久久久人成影片一区二区三区| 日韩免费不卡av| 欧美性猛交xxxx乱大交蜜桃| 欧美性猛交xxxx乱大交极品| 久久精品国产一区二区三区| 丰满岳妇乱一区二区三区| 国产成人免费av| 色噜噜狠狠狠综合曰曰曰88av| 国产精品福利网| 国产精品网址在线| 久久亚洲影音av资源网| 亚洲色图偷窥自拍| 成人精品一区二区三区| 日韩欧美高清视频| 热99精品里视频精品| 日韩国产精品亚洲а∨天堂免| 欧美成人精品在线观看| 色综合久久中文字幕综合网小说| 久久精品久久久久电影| 欧美性猛交99久久久久99按摩| 国产精品自产拍高潮在线观看| 91精品国产自产在线老师啪| 亚洲国产精品久久精品怡红院| 精品中文字幕视频| 欧美日韩国产区| 91av在线视频观看| 国产自产女人91一区在线观看| 亚洲一区二区三区sesese| 国产精品亚洲自拍| 国模叶桐国产精品一区| 久久精品亚洲94久久精品| 中文字幕精品www乱入免费视频| 亚洲第一中文字幕| 精品视频—区二区三区免费| 中文字幕亚洲一区| 国产日韩av高清| 青青草99啪国产免费| 亚洲影院色无极综合|