條件編譯絕對是一個好東西。如在C或CPP中,可以通過預(yù)處理語句來實現(xiàn)條件編譯。代碼如下:
#IFDEF DEBUG #UNDEF DEBUG #ENDIF #define DEBUG #IFDEF DEBUUG /* code block 1 */ #ELSE /* code block 2 */ #ENDIF |
但是在JAVA中卻沒有預(yù)處理,宏定義這些東西,而有時在一些項目中,我們又需要條件編譯。那么,在JAVA中,該如何實現(xiàn)條件編譯呢?
我們來看一個例子。
編寫一個helloworld程序。代碼如下:
public class Hello { public static void main(String[] args) { System.out.println("Hello, world!"); } } |
保存為Hello.java并編譯,得到一個class文件,并且觀察到文件大小是417字節(jié)。然后我們對這個文件進行反編譯,用jd-gui。得到代碼如下:
import java.io.PrintStream; public class Hello { public static void main(String[] paramArrayOfString) { System.out.println("Hello, world!"); } } |
得到這個有什么用呢?
現(xiàn)在我們再來對源代碼進行修改,修改后的代碼如下。
public class Hello { public static void main(String[] args) { if(false) { System.out.println("Hello, world!"); } } } |
進行編譯,這時我們再看它的大小,只有255字節(jié)。怎樣?想到什么了吧?沒錯,編譯器會對代碼進行優(yōu)化,對于條件永遠(yuǎn)為false的語句,JAVA編譯器將不會對其生成字節(jié)碼。下面我們再來對該class文件進行反編譯,果然代碼如下:
public class Hello { public static void main(String[] paramArrayOfString) { } } |
利用JAVA編譯的這一優(yōu)化機制,我們就可以實現(xiàn)JAVA的條件編譯了。
public class Hello { public static void main(String[] args) { if(false) { System.out.println("Hello, world!"); } } } |
定義一個final的變量,然后再在if語句中使用。代碼如下:
public class Hello { public static void main(String[] args) { final boolean DEBUG = true; if(DEBUG) { System.out.println("Hello, world!"); } } } |
當(dāng)條件編譯使用得多時,上面將極不利于代碼的修改及維護,這時就可以用一種更為靈活的方法。定義一個靜態(tài)類,里面專門定義用來控制條件編譯的變量。然后再在具體的代碼中導(dǎo)入該類,使用這些final變量。代碼如下:
public class DebugConfig { public static final boolean BLUETOOTH_DEBUG = false; public static final boolean WIRELESS_DEBUG = false; } |
if ( DebugConfig.BLUETOOTH_DEBUG) { // TODO } |