91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Ruby信號處理的方法

發布時間:2022-04-18 13:50:15 來源:億速云 閱讀:145 作者:iii 欄目:開發技術

這篇文章主要介紹“Ruby信號處理的方法”的相關知識,小編通過實際案例向大家展示操作過程,操作方法簡單快捷,實用性強,希望這篇“Ruby信號處理的方法”文章能幫助大家解決問題。

Ruby使用Process.kill發送信號

Process.kill(signal, pid, ...) → integer

Process.kill發送指定的信號給一個或多個進程或進程組:

  • 如果目標pid>0,表示發送信號給指定PID的進程

  • 如果目標pid=0,表示發送信號給調用kill的進程所在進程組的所有進程

  • 如果目標pid<0,表示按照操作系統的規則發送信號。對于Linux來說:

    • 如果pid=-1,表示發送信號給除pid=1的init進程外的所有進程,當然,沒有權限的進程將不受影響

    • 如果pid<-1,表示發送信號給-pid所在進程組的所有進程,例如-3000表示發送信號給pid=3000的進程所在進程組的所有進程

Process.kill的第一個參數是要發送的信號:

  • 信號可以是字符串格式的信號名或數值格式的信號ID,INT或SIGINT或1都是有效的信號

  • 如果信號帶有負號(如-2-INT),表示發送信號給進程所在進程組而非指定的進程(Linux不支持帶負號的信號)

  • 如果信號為0,表示探測是否能發送信號給目標進程,可探測是否能管理目標進程或者探測目標進程是否存活

pid = fork do
  sleep 300
end
# ...
Process.kill("HUP", pid)
Process.wait

Ruby使用trap()設置信號處理程序

Ruby中使用Kernel.trapSignal.trap捕獲信號并設置信號處理程序,這兩個trap等價。

可設置多個trap來監控多個信號。

Signal.trap(0, proc { puts "Terminating: #{$$}" })
Signal.trap("CLD")  { puts "Child died" }
fork && Process.wait
=begin
Terminating: 27461
Child died
Terminating: 27460
=end

trap的第一個參數是監控的信號名稱,可以是字符串的信號名稱(如SIGINT),可以是省略SIG前綴的信號名稱(如INT),可以是信號對應的數值(如2)。

Ruby支持一個特殊的信號0(對應的字符串信號名為EXIT或SIGEXIT),表示進程退出時會觸發的信號。

trap的第二個參數或語句塊是捕獲到信號后執行的代碼。第二個參數有幾種特殊情況:

  • 如果第二個參數為字符串IGNORESIG_IGN,表示忽略本次捕獲的信號

  • 如果第二個參數為字符串DEFAULTSIG_DFL,表示按照Ruby的默認處理規則來處理

  • 如果第二個參數為字符串EXIT,表示以退出狀態碼0退出當前進程

  • 如果第二個參數為字符串SYSTEM_DEFAULT,表示按照系統的默認信號處理規則來處理,即以退出狀態碼141退出進程

避免信號覆蓋

使用第三方包的時候,有時候不知道這個包是否定義了某個信號的信號處理程序,或者知道它定義了某信號信號處理程序,但自己定義這個信號的信號處理程序時,不想覆蓋第三方包中所定義的處理程序。

這時,應該利用好trap的返回值。每一次trap設置信號處理程序時,都返回本信號之前已經定義的信號處理程序(是一個Proc對象)。只是需要注意,有些信號的初始處理程序是一個字符串值DEFAULT而不是一個Proc對象,因此,應該進行類型判斷:

# 第一次定義INT的信號處理程序
first_trap = trap('INT') { 
  first_trap.call if first_trap.is_a? Proc
  puts "first_trap" 
}

# 第二次定義INT的信號處理程序
old_trap = trap('INT') { 
  old_trap.call if old_trap.is_a? Proc   # 調用第一次定義的信號處理程序
  puts "old trap"  # 本次trap時執行的邏輯
}
# 定義好之后,old_trap為第一次定義的信號處理程序

# 之后按下CTRL+C觸發INT信號的信號處理程序

多線程信號注冊問題

如果是在多線程中注冊信號處理程序,該信號處理程序將總是注冊在所在進程的main線程中(即使是在其它線程中設置trap())。

pid = fork do
  puts "main Thread: #{Thread.current}"
  Thread.new {
    puts "new Thread: #{Thread.current}"
    trap("TERM", proc { puts "Signal: #{Thread.current}" })
    sleep 2
  }
  sleep 2
end

sleep 1
Process.kill 'SIGTERM', pid
=begin
main Thread: #<Thread:0x00007fffd6ed4c10 run>
new Thread: #<Thread:0x00007fffd714f2b0@a.rb:4 run>
Signal: #<Thread:0x00007fffd6ed4c10 run>
=end

子進程繼承信號處理程序

子進程會從父進程繼承信號處理程序。

trap 'TERM', proc { puts "Signal: #{Process.pid}" }
puts "Parent: #{Process.pid}"

pid = fork do
  sleep 30
end

puts "Child: #{pid}"
Process.kill 'TERM', pid
=begin
Parent: 2872
Child: 2901
Signal: 2901
=end

關于“Ruby信號處理的方法”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識,可以關注億速云行業資訊頻道,小編每天都會為大家更新不同的知識點。

向AI問一下細節
推薦閱讀:
  1. ruby 的while
  2. ruby的if判斷

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

临朐县| 青浦区| 枣阳市| 汶上县| 博罗县| 奉节县| 高青县| 巨鹿县| 铜川市| 太保市| 黄陵县| 额尔古纳市| 凤台县| 福泉市| 井陉县| 龙门县| 阜南县| 紫金县| 丹江口市| 清原| 北海市| 巴林左旗| 陆川县| 灵川县| 无为县| 高阳县| 淅川县| 临潭县| 奉新县| 休宁县| 嵊泗县| 莲花县| 曲阜市| 永州市| 周宁县| 南岸区| 岱山县| 天津市| 怀来县| 平乐县| 黄梅县|