好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > 詳解Ruby中的異常

詳解Ruby中的異常

熱門標簽:巫師3地圖標注魔力之所 柯城手機地圖如何做地圖標注 淮安自動外呼系統(tǒng)供應商 AI電銷機器人 線路 天津外呼系統(tǒng)怎么收費 外呼線路從哪里出來的 漯河電銷 征服者企業(yè)地圖標注 中牟外呼系統(tǒng)違法嗎

異常和執(zhí)行總是被聯(lián)系在一起。如果您打開一個不存在的文件,且沒有恰當?shù)靥幚磉@種情況,那么您的程序則被認為是低質(zhì)量的。

如果異常發(fā)生,則程序停止。異常用于處理各種類型的錯誤,這些錯誤可能在程序執(zhí)行期間發(fā)生,所以要采取適當?shù)男袆樱恢劣谧尦绦蛲耆V埂?/p>

Ruby 提供了一個完美的處理異常的機制。我們可以在 begin/end 塊中附上可能拋出異常的代碼,并使用 rescue 子句告訴 Ruby 完美要處理的異常類型。
語法

begin 
# - 
rescue OneTypeOfException 
# - 
rescue AnotherTypeOfException 
# - 
else 
# 其他異常
ensure
# 總是被執(zhí)行
end

從 begin 到 rescue 中的一切是受保護的。如果代碼塊執(zhí)行期間發(fā)生了異常,控制會傳到 rescue 和 end 之間的塊。

對于 begin 塊中的每個 rescue 子句,Ruby 把拋出的異常與每個參數(shù)進行輪流比較。如果 rescue 子句中命名的異常與當前拋出的異常類型相同,或者是該異常的父類,則匹配成功。

如果異常不匹配所有指定的錯誤類型,我們可以在所有的 rescue 子句后使用一個 else 子句。
實例

#!/usr/bin/ruby
 
begin
  file = open("/unexistant_file")
  if file
   puts "File opened successfully"
  end
rescue
   file = STDIN
end
print file, "==", STDIN, "\n"

這將產(chǎn)生以下結果。您可以看到,STDIN 取代了 file ,因為打開失敗。
#IO:0xb7d16f84>==#IO:0xb7d16f84>
使用 retry 語句

您可以使用 rescue 塊捕獲異常,然后使用 retry 語句從開頭開始執(zhí)行 begin 塊。
語法

begin
  # 這段代碼拋出的異常將被下面的 rescue 子句捕獲
rescue
  # 這個塊將捕獲所有類型的異常
  retry # 這將把控制移到 begin 的開頭
end
實例
#!/usr/bin/ruby
 
begin
  file = open("/unexistant_file")
  if file
   puts "File opened successfully"
  end
rescue
  fname = "existant_file"
  retry
end

以下是處理流程:

  1.     打開時發(fā)生異常。
  2.     跳到 rescue。fname 被重新賦值。
  3.     通過 retry 跳到 begin 的開頭。
  4.     這次文件成功打開。
  5.     繼續(xù)基本的過程。

注意:如果被重新命名的文件不存在,本勢力代碼會無限嘗試。所以異常處理時,謹慎使用 retry。
使用 raise 語句

您可以使用 raise 語句拋出異常。下面的方法在調(diào)用時拋出異常。它的第二個消息將被輸出。
語法

raise
 
OR
 
raise "Error Message"
 
OR
 
raise ExceptionType, "Error Message"
 
OR
 
raise ExceptionType, "Error Message" condition

第一種形式簡單地重新拋出當前異常(如果沒有當前異常則拋出一個 RuntimeError)。這用在傳入異常之前需要解釋異常的異常處理程序中。

第二種形式創(chuàng)建一個新的 RuntimeError 異常,設置它的消息為給定的字符串。該異常之后拋出到調(diào)用堆棧。

第三種形式使用第一個參數(shù)創(chuàng)建一個異常,然后設置相關的消息為第二個參數(shù)。

第四種形式與第三種形式類似,您可以添加任何額外的條件語句(比如 unless)來拋出異常。
實例

#!/usr/bin/ruby
 
begin 
  puts 'I am before the raise.' 
  raise 'An error has occurred.' 
  puts 'I am after the raise.' 
rescue 
  puts 'I am rescued.' 
end 
puts 'I am after the begin block.' 

這將產(chǎn)生以下結果:

I am before the raise. 
I am rescued. 
I am after the begin block. 

另一個演示 raise 用法的實例:

#!/usr/bin/ruby
 
begin 
 raise 'A test exception.' 
rescue Exception => e 
 puts e.message 
 puts e.backtrace.inspect 
end 

這將產(chǎn)生以下結果:

A test exception.
["main.rb:4"]

使用 ensure 語句

有時候,無論是否拋出異常,您需要保證一些處理在代碼塊結束時完成。例如,您可能在進入時打開了一個文件,當您退出塊時,您需要確保關閉文件。

ensure 子句做的就是這個。ensure 放在最后一個 rescue 子句后,并包含一個塊終止時總是執(zhí)行的代碼塊。它與塊是否正常退出、是否拋出并處理異常、是否因一個未捕獲的異常而終止,這些都沒關系,ensure 塊始終都會運行。
語法

begin
  #.. 過程
  #.. 拋出異常
rescue
  #.. 處理錯誤
ensure
  #.. 最后確保執(zhí)行
  #.. 這總是會執(zhí)行
end
實例
begin
 raise 'A test exception.'
rescue Exception => e
 puts e.message
 puts e.backtrace.inspect
ensure
 puts "Ensuring execution"
end

這將產(chǎn)生以下結果:

A test exception.
["main.rb:4"]
Ensuring execution

使用 else 語句

如果提供了 else 子句,它一般是放置在 rescue 子句之后,任意 ensure 之前。

else 子句的主體只有在代碼主體沒有拋出異常時執(zhí)行。
語法

begin
  #.. 過程
  #.. 拋出異常
rescue
  #.. 處理錯誤
else
  #.. 如果沒有異常則執(zhí)行
ensure
  #.. 最后確保執(zhí)行
  #.. 這總是會執(zhí)行
end
實例
begin
 # 拋出 'A test exception.'
 puts "I'm not raising exception"
rescue Exception => e
 puts e.message
 puts e.backtrace.inspect
else
  puts "Congratulations-- no errors!"
ensure
 puts "Ensuring execution"
end

這將產(chǎn)生以下結果:

I'm not raising exception
Congratulations-- no errors!
Ensuring execution

使用 $! 變量可以捕獲拋出的錯誤消息。
Catch 和 Throw

raise 和 rescue 的異常機制能在發(fā)生錯誤時放棄執(zhí)行,有時候需要在正常處理時跳出一些深層嵌套的結構。此時 catch 和 throw 就派上用場了。

catch 定義了一個使用給定的名稱(可以是 Symbol 或 String)作為標簽的塊。塊會正常執(zhí)行知道遇到一個 throw。
語法

throw :lablename
#.. 這不會被執(zhí)行
catch :lablename do
#.. 在遇到一個 throw 后匹配將被執(zhí)行的 catch
end
 
OR
 
throw :lablename condition
#.. 這不會被執(zhí)行
catch :lablename do
#.. 在遇到一個 throw 后匹配將被執(zhí)行的 catch
end

實例

下面的實例中,如果用戶鍵入 '!' 回應任何提示,使用一個 throw 終止與用戶的交互。

def promptAndGet(prompt)
  print prompt
  res = readline.chomp
  throw :quitRequested if res == "!"
  return res
end
 
catch :quitRequested do
  name = promptAndGet("Name: ")
  age = promptAndGet("Age: ")
  sex = promptAndGet("Sex: ")
  # ..
  # 處理信息
end
promptAndGet("Name:")

上面的程序需要人工交互,您可以在您的計算機上進行嘗試。這將產(chǎn)生以下結果:

Name: Ruby on Rails
Age: 3
Sex: !
Name:Just Ruby

類 Exception

Ruby 的標準類和模塊拋出異常。所有的異常類組成一個層次,包括頂部的 Exception 類在內(nèi)。下一層是七種不同的類型:

  1.     Interrupt
  2.     NoMemoryError
  3.     SignalException
  4.     ScriptError
  5.     StandardError
  6.     SystemExit
  7.     Fatal 是該層中另一種異常,但是 Ruby 解釋器只在內(nèi)部使用它。

ScriptError 和 StandardError 都有一些子類,但是在這里我們不需要了解這些細節(jié)。最重要的事情是創(chuàng)建我們自己的異常類,它們必須是類 Exception 或其子代的子類。

讓我們看一個實例:

class FileSaveError  StandardError
  attr_reader :reason
  def initialize(reason)
   @reason = reason
  end
end

現(xiàn)在,看下面的實例,將用到上面的異常:

File.open(path, "w") do |file|
begin
  # 寫出數(shù)據(jù) ...
rescue
  # 發(fā)生錯誤
  raise FileSaveError.new($!)
end
end

在這里,最重要的一行是 raise FileSaveError.new($!)。我們調(diào)用 raise 來示意異常已經(jīng)發(fā)生,把它傳給 FileSaveError 的一個新的實例,由于特定的異常引起數(shù)據(jù)寫入失敗。

您可能感興趣的文章:
  • ruby 異常處理:ensure
  • ruby 異常處理:rescue
  • Ruby中的異常處理代碼編寫示例

標簽:棗莊 甘孜 南昌 克拉瑪依 內(nèi)江 西雙版納 大慶 河池

巨人網(wǎng)絡通訊聲明:本文標題《詳解Ruby中的異常》,本文關鍵詞  詳解,Ruby,中的,異常,詳解,;如發(fā)現(xiàn)本文內(nèi)容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《詳解Ruby中的異常》相關的同類信息!
  • 本頁收集關于詳解Ruby中的異常的相關信息資訊供網(wǎng)民參考!
  • 推薦文章
    主站蜘蛛池模板: 室友粗大h| 国内精品久久久久影院日本| 色戒无删减电影| 91亚洲 欧美 国产 综合| 久久伊人影院| 精品免费国产一区二区三区四区介绍| 肉书阁| 少妇户外露出[11p]| 欧美AV蜜桃一区二区蜜桃| 兄妹高h文| 久久66久这里只有精品99 | 欧美一区二区三区电影| 用力?哦?高潮?喷了舌交| 极品美軳人体GOGO| 精品国产乱码久久久久久一区二区| 快穿之H被cao哭高H奶水视频| 公司的员工味道中字强多人| 女人又爽?又黄?动漫下载| avtom影院入口永久在线app| 秋霞国产精品一区二区| 少女战机| 国产午夜鲁丝片Av无码免费| 一个人的视频日本免费| 西西裸体性猛交乱大XXXX| 中文字幕日韩wm二在线看| 免费成人小视频| 婬荡的寡妇在线HD播放| 一级中国毛片| 差差差很疼的30分钟免费软件| 狠狠色噜噜狠狠狠狠97不卡| 国产亚洲精品久久无码小说| 俄罗斯美女A片免费看| 精品国产国语对白主播野战| 亚洲欧美一区在线| 九色91POPNY丨九色囯产| japanesexxxxx公交车| 精品乱码一区二区三四区| 摸奶图| 国外B站推广网站| 艳魔大战2春荡女婬无删减| 把女的下面扒开添视频|