Java陷阱之assert關鍵字
1、概述
在C和C++語言中都有assert關鍵,表示斷言。
在Java中,一樣也有assert關鍵字,表示斷言,用法和含義都差很少。
2、語法
在Java中,assert關鍵字是從JAVA SE 1.4 引入的,爲了不和老版本的Java代碼中使用了assert關鍵字致使錯誤,Java在執行的時候默認是不啓動斷言檢查的(這個時候,全部的斷言語句都將忽略!),若是要開啓斷言檢查,則須要用開關-enableassertions或-ea來開啓。
assert關鍵字語法很簡單,有兩種用法:
一、assert <boolean表達式>
若是<boolean表達式>爲true,則程序繼續執行。
若是爲false,則程序拋出AssertionError,並終止執行。
二、assert <boolean表達式> : <錯誤信息表達式>
若是<boolean表達式>爲true,則程序繼續執行。
若是爲false,則程序拋出java.lang.AssertionError,並輸入<錯誤信息表達式>。
3、應用實例
下面給出一個例子,經過例子說明其用法:
public
class
AssertFoo {
public
static
void
main(String args[]) {
//
斷言
1
結果爲
true
,則繼續往下執行
assert
true
;
System.
out
.println(
"
斷言
1
沒有問題,
Go
!
"
);
System.
out
.println(
"\n-----------------\n"
);
//
斷言
2
結果爲
false,程序終止
assert
false
:
"
斷言失敗,此表達式的信息將會在拋出異常的時候輸出!
"
;
System.
out
.println(
"
斷言
2
沒有問題,
Go
!
"
);
}
}
保存代碼到C:\AssertFoo.java,而後按照下面的方式執行,查看控制檯輸出結果:
一、編譯程序:
C:\>javac AssertFoo.java
二、默認執行程序,沒有開啓-ea開關:
C:\>java AssertFoo
斷言1沒有問題,Go!
-----------------
斷言2沒有問題,Go!
三、開啓-ea開關,執行程序:
C:\>java -ea AssertFoo
斷言1沒有問題,Go!
-----------------
Exception in thread "main" java.lang.AssertionError:
斷言失敗,此表達式的信息將
會在拋出異常的時候輸出!
at AssertFoo.main(AssertFoo.java:10)
4、陷阱
assert關鍵字用法簡單,可是使用assert每每會讓你陷入愈來愈深的陷阱中。應避免使用。筆者通過研究,總結了如下緣由:
一、assert關鍵字須要在運行時候顯式開啓才能生效,不然你的斷言就沒有任何意義。而如今主流的Java IDE工具默認都沒有開啓-ea斷言檢查功能。這就意味着你若是使用IDE工具編碼,調試運行時候會有必定的麻煩。而且,對於Java Web應用,程序代碼都是部署在容器裏面,你無法直接去控制程序的運行,若是必定要開啓-ea的開關,則須要更改Web容器的運行配置參數。這對程序的移植和部署都帶來很大的不便。
二、用assert代替if是陷阱之二。assert的判斷和if語句差很少,但二者的做用有着本質的區別:assert關鍵字本意上是爲測試調試程序時使用的,但若是不當心用assert來控制了程序的業務流程,那在測試調試結束後去掉assert關鍵字就意味着修改了程序的正常的邏輯。
三、assert斷言失敗將面臨程序的退出。這在一個生產環境下的應用是毫不能容忍的。通常都是經過異常處理來解決程序中潛在的錯誤。可是使用斷言就很危險,一旦失敗系統就掛了。
5、對assert的思考
assert既然是爲了調試測試程序用,不在正式生產環境下用,那應該考慮更好的測試JUint來代替其作用,JUint相對assert關鍵的所提供的功能是有過之而無不及。固然徹底能夠經過IDE debug來進行調試測試。在此看來,assert的前途一片昏暗。
所以,應當避免在Java中使用assert關鍵字,除非哪一天Java默認支持開啓-ea的開關,這時候能夠考慮。對比一下,assert能給你帶來多少好處,多少麻煩,這是咱們選擇是否使用的的原則。
以上僅僅表明我我的觀點,歡迎你們留言討論。