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)代語言,我們可以通過隔離的辦法處理代碼域里的異常,因此,這有著驚人的效果卻又不會為程序員或以后希望讀它的其它人造成過度的負(fù)擔(dān).代碼域由begin開始直到遇到一個異常,這將導(dǎo)致轉(zhuǎn)向一個由rescue標(biāo)記的錯誤處理代碼域.如果異常沒發(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)造性工作.這里,如果文件不存在,我們用標(biāo)準(zhǔn)輸入代替:
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)代語言,我們可以通過隔離的辦法處理代碼域里的異常,因此,這有著驚人的效果卻又不會為程序員或以后希望讀它的其它人造成過度的負(fù)擔(dān).代碼域由begin開始直到遇到一個異常,這將導(dǎo)致轉(zhuǎn)向一個由rescue標(biāo)記的錯誤處理代碼域.如果異常沒發(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)造性工作.這里,如果文件不存在,我們用標(biāo)準(zhǔn)輸入代替:
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中正則表達(dá)式對字符串的匹配和替換操作
- 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解析處理YAML和json格式數(shù)據(jù)
這篇文章主要介紹了Ruby對YAML和json格式的數(shù)據(jù)處理方法,json序列化、json反序列化,json解析等操作,需要的朋友可以參考下2022-04-04Java 版的 Ruby 解釋器 JRuby 1.7.14 發(fā)布
JRuby,一個采用純Java實現(xiàn)的Ruby解釋器,由JRuby團(tuán)隊開發(fā)。它是一個自由軟件,在CPL/GPL/LGPL三種許可協(xié)議下發(fā)布。2014-08-08解析proxy代理模式在Ruby設(shè)計模式開發(fā)中的運用
這篇文章主要介紹了proxy代理模式在Ruby設(shè)計模式開發(fā)中的運用,通過代理模式以客戶透明的形式可以動態(tài)地為目標(biāo)對象加以行為控制,需要的朋友可以參考下2016-04-04