ruby 異常處理:rescue
更新時間:2007年11月24日 14:21:27 作者:
一個運行著的程序常會遇到意外的問題.一個要讀取的文件不存在;當(dāng)希望存入一些數(shù)據(jù)時磁盤滿了;用戶可能輸入不恰當(dāng)?shù)臄?shù)據(jù).
ruby> file = open("some_file")
ERR: (eval):1:in `open': No such file or directory - some_file
一個健壯的程序會合理并漂亮的處理這些問題.面對那些異常是一件討人厭的工作.C程序員被要求做到檢查每一個可能導(dǎo)致錯誤發(fā)生的系統(tǒng)調(diào)用的返回值并立刻做出決定.
FILE *file = fopen("some_file", "r");
if (file == NULL) {
fprintf( stderr, "File doesn't exist.\n" );
exit(1);
}
bytes_read = fread( buf, 1, bytes_desired, file );
if (bytes_read != bytes_desired ) {
/* do more error handling here ... */
}
...
這項無聊的工作會使程序員最終變得馬虎并忽略掉它,結(jié)果是程序無法應(yīng)對異常.令一方面,這樣也會降低程序的可讀性.因為過多的錯誤處理使有意義的代碼也變得雜亂了.
在Ruby里,就像其它的現(xiàn)代語言,我們可以通過隔離的辦法處理代碼域里的異常,因此,這有著驚人的效果卻又不會為程序員或以后希望讀它的其它人造成過度的負擔(dān).代碼域由begin開始直到遇到一個異常,這將導(dǎo)致轉(zhuǎn)向一個由rescue標記的錯誤處理代碼域.如果異常沒發(fā)生,rescue代碼就不會使用.下面的代碼返回文本文件的第一行,如果有異常則返回 nil.
def first_line( filename )
begin
file = open("some_file")
info = file.gets
file.close
info # Last thing evaluated is the return value
rescue
nil # Can't read the file? then don't return a string
end
end
有時我們會希望圍繞問題展開創(chuàng)造性工作.這里,如果文件不存在,我們用標準輸入代替:
begin
file = open("some_file")
rescue
file = STDIN
end
begin
# ... process the input ...
rescue
# ... and deal with any other exceptions here.
end
retry 用于 rescue 代碼表示又重新執(zhí)行 begin 代碼.這讓我們可以壓縮前面的例子:
fname = "some_file"
begin
file = open(fname)
# ... process the input ...
rescue
fname = "STDIN"
retry
end
但這仍有一點瑕疵.一個不存在的文件將導(dǎo)致不停止地 retry.你在使用 retry 做異常處理時應(yīng)注意到這一點.
每個Ruby庫在遇到錯誤時都會提交一個異常,你可以在自己的代碼里明確地提交異常.用 raise 來提交異常.它帶一個參數(shù),也就是描述異常的一個字符串.參數(shù)是可選的但不應(yīng)被省略.之后它可以通過一個特殊的全局變量 $! 訪問.
ruby> raise "test error"
test error
ruby> begin
| raise "test2"
| rescue
| print "An error occurred: ",$!, "\n"
| end
An error occurred: test2
nil
ruby> file = open("some_file")
ERR: (eval):1:in `open': No such file or directory - some_file
一個健壯的程序會合理并漂亮的處理這些問題.面對那些異常是一件討人厭的工作.C程序員被要求做到檢查每一個可能導(dǎo)致錯誤發(fā)生的系統(tǒng)調(diào)用的返回值并立刻做出決定.
FILE *file = fopen("some_file", "r");
if (file == NULL) {
fprintf( stderr, "File doesn't exist.\n" );
exit(1);
}
bytes_read = fread( buf, 1, bytes_desired, file );
if (bytes_read != bytes_desired ) {
/* do more error handling here ... */
}
...
這項無聊的工作會使程序員最終變得馬虎并忽略掉它,結(jié)果是程序無法應(yīng)對異常.令一方面,這樣也會降低程序的可讀性.因為過多的錯誤處理使有意義的代碼也變得雜亂了.
在Ruby里,就像其它的現(xiàn)代語言,我們可以通過隔離的辦法處理代碼域里的異常,因此,這有著驚人的效果卻又不會為程序員或以后希望讀它的其它人造成過度的負擔(dān).代碼域由begin開始直到遇到一個異常,這將導(dǎo)致轉(zhuǎn)向一個由rescue標記的錯誤處理代碼域.如果異常沒發(fā)生,rescue代碼就不會使用.下面的代碼返回文本文件的第一行,如果有異常則返回 nil.
def first_line( filename )
begin
file = open("some_file")
info = file.gets
file.close
info # Last thing evaluated is the return value
rescue
nil # Can't read the file? then don't return a string
end
end
有時我們會希望圍繞問題展開創(chuàng)造性工作.這里,如果文件不存在,我們用標準輸入代替:
begin
file = open("some_file")
rescue
file = STDIN
end
begin
# ... process the input ...
rescue
# ... and deal with any other exceptions here.
end
retry 用于 rescue 代碼表示又重新執(zhí)行 begin 代碼.這讓我們可以壓縮前面的例子:
fname = "some_file"
begin
file = open(fname)
# ... process the input ...
rescue
fname = "STDIN"
retry
end
但這仍有一點瑕疵.一個不存在的文件將導(dǎo)致不停止地 retry.你在使用 retry 做異常處理時應(yīng)注意到這一點.
每個Ruby庫在遇到錯誤時都會提交一個異常,你可以在自己的代碼里明確地提交異常.用 raise 來提交異常.它帶一個參數(shù),也就是描述異常的一個字符串.參數(shù)是可選的但不應(yīng)被省略.之后它可以通過一個特殊的全局變量 $! 訪問.
ruby> raise "test error"
test error
ruby> begin
| raise "test2"
| rescue
| print "An error occurred: ",$!, "\n"
| end
An error occurred: test2
nil
您可能感興趣的文章:
- Ruby學(xué)習(xí)筆記之gem 命令詳解
- Ruby rails 頁面跳轉(zhuǎn)(render和redirect_to)
- Ruby 字符串處理
- RUBY 新手教程 跟我一起學(xué)ruby
- 學(xué)習(xí)Ruby你需要了解的相關(guān)知識(rvm, gem, bundle, rake, rails等)
- Ruby中執(zhí)行Linux shell命令的六種方法詳解
- 淘寶網(wǎng)提供的國內(nèi)RubyGems鏡像簡介和使用方法
- 二十分鐘 教你Ruby快速入門 圖文教程
- 詳解Ruby中正則表達式對字符串的匹配和替換操作
- Ruby Gems更換淘寶源方法
- Windows下Ruby on Rails開發(fā)環(huán)境安裝配置圖文教程
- ruby 學(xué)習(xí)筆記(2) 類的基本使用
- CentOS 6.3下編譯安裝Ruby 2.0筆記
- Ruby中的return、break、next詳解
- 舉例講解Ruby中require的使用方法
- 更改RubyGem安裝源
- 使用Ruby來處理JSON的簡單教程
- Ruby信號處理詳解
相關(guān)文章
Ruby配置rspec和RestClient來檢測服務(wù)器
這篇文章主要介紹了Ruby配置rspec和RestClient來檢測服務(wù)器的方法,包括JSON文件的相關(guān)配置,需要的朋友可以參考下2015-07-07
借助RubyGnome2庫進行GTK下的Ruby GUI編程的基本方法
這篇文章主要介紹了借助RubyGnome2庫進行GTK下的Ruby GUI編程的基本方法,介紹了基本的UI和事件響應(yīng)的相關(guān)實現(xiàn),需要的朋友可以參考下2015-12-12
Linux系統(tǒng)上配置Nginx+Ruby on Rails+MySQL超攻略
這篇文章主要介紹了Linux系統(tǒng)上配置Nginx+Ruby on Rails+MySQL超攻略,用到了RVM,此種服務(wù)器搭建配置極力推薦!需要的朋友可以參考下2015-08-08
Luhn算法學(xué)習(xí)及其Ruby版實現(xiàn)代碼示例
Luhn算法主要北用來進行數(shù)字驗證,尤其是卡號身份證號等,這里我們就來看一下Luhn算法學(xué)習(xí)及其Ruby版實現(xiàn)代碼示例:2016-05-05

