我的项目需要Java 1.6进行编译和运行。现在,我有一个要求使其与Java 1.5一起使用(从市场营销方面)。我想替换方法主体(返回类型和参数保持相同),以使其在Java 1.5中编译时没有错误。详细信息:我有一个称为的实用程序类OS,它封装所有特定于操作系统的内容。它有一种方法public static void openFile(java.io.File file) throws java.io.IOException { // open the file using java.awt.Desktop ...}双击打开文件(相当于startWindows命令或openMac OS X命令)。由于无法使用Java 1.5进行编译,因此我想在编译过程中将其排除在外,并使用调用run32dllWindows或openMac OS X 的另一种方法代替Runtime.exec。问题:我该怎么做?注释可以在这里提供帮助吗?注意:我使用ant,我可以制作两个java文件OS4J5.java,OS4J6.java其中将包含OS具有Java 1.5和1.6所需代码的类,并OS.java在编译之前将其中一个复制到其中(或以丑陋的方式- OS.java根据Java 替换有条件的内容)版本),但如果有其他方法,我也不想这样做。详细说明:在CI中可以使用ifdef, ifndef,在Python中没有编译,我可以使用hasattr或其他方式检查功能,在Common Lisp中可以使用#+feature。Java有类似的东西吗?
3 回答

慕丝7291255
TA贡献1859条经验 获得超6个赞
不,Java不支持条件编译。
通常的计划是将应用的特定于操作系统的位隐藏在后面Interface,然后在运行时检测操作系统类型并使用加载实现Class.forName(String)。
在您的情况下,没有理由不能OS*使用Java 1.6 编译两者(并影响整个应用程序),-source 1.5 -target 1.5然后在用于获取OS类的工厂方法(现在将是接口)中检测到java.awt.Desktop
该类可用并且加载正确的版本。
就像是:
public interface OS {
void openFile(java.io.File file) throws java.io.IOException;
}
public class OSFactory {
public static OS create(){
try{
Class.forName("java.awt.Desktop");
return new OSJ6();
}catch(Exception e){
//fall back
return new OSJ5();
}
}
}
添加回答
举报
0/150
提交
取消