首先,我們有必要從一個例子說起assert
public class AssertTest
{
public static void main(String[] args)
{
AssertTest at = new AssertTest();
at.assertMe(true);
at.assertMe(false);
}
PRivate void assertMe(boolean boo)
{
assert boo?true:false;
System.out.println("true condition");
}
}
程序中包含了assert的話,你要用javac -source 1.4 xxx.java來編譯,否則編譯器會報錯的。要想讓assert得部分運行的話,要使用java -ea xxx來運行,否則包含assert得行會被忽略。下面我們運行
javac -source 1.4 AssertTest.java
java -ea AssertTest
看看結果的輸出是:
true condition
Exception in thread "main" java.lang.AssertionError
at AssertTest.assertMe(AssertTest.java:13)
at AssertTest.main(AssertTest.java:7)
當我們運行at.assertMe(true)得時候,由于assert boo?true:false相當于 assert true;因此沒有任何問題,程序往下執行打印出true condition,但是執行at.assertMe(false)的時候相當于assert false,這個時候解釋器就會拋出AssertionError了,程序就終止了。大家必須清楚AssertionError是繼續自Error得,因此你可以不再程序中catch它的,當然你也可以在程序中catch它然后程序可以繼續執行。例如:
public class AssertTest
{
public static void main(String[] args)
{
AssertTest at = new AssertTest();
try
{
at.assertMe(true);
at.assertMe(false);
}
catch(AssertionError ae)
{
System.out.println("AsseriontError catched");
}
System.out.println("go on");
}
private void assertMe(boolean boo)
{
assert boo?true:false;
System.out.println("true condition");
}
}
assert還有另外一種表達的方式,就是assert eXP1:exp2;其中exp1是個boolean返回值得表達式,而exp2可以是原始的數據類型或者對象都可以例如:
boolean boo = true;
String str = null;
assert boo = false:str="error";
我們剛開始講得assert exp1得形式,當exp1是false得時候,AssertionError得默認構造器會被調用,但是assert exp1:exp2這樣的形式,當exp1為true的時候后面exp2被或略,假如false的話,后面的表達式的結果會被計算出來并作為AssertionError得構造器參數。看下面的例子:
public class AssertTest
{
public static void main(String[] args)
{
AssertTest at = new AssertTest();
at.assertMe(true);
at.assertMe(false);
}
private void assertMe(boolean boo)
{
String s = null;
assert boo?true:false:s = "hello world";
System.out.println("true condition");
}
}運行的時候會得到這樣的結果
true condition
Exception in thread "main" java.lang.AssertionError: hello world
at AssertTest.assertMe(AssertTest.java:14)
at AssertTest.main(AssertTest.java:7)
Assert最好不要濫用,原因是assert并不一定都是enable的,下面兩種情況就不應該用assert
新聞熱點
疑難解答