我有一个使用带有
<javac target="1.5" ... />
的 ant 文件从编译的类文件生成的 jar 文件,我想验证它是否确实生成 1.5 代码。有办法做到这一点吗?
我使用的其中一台计算机中的 MATLAB 版本使用 JRE 1.5;因此除非它与 JRE 1.5 兼容,否则它不会运行代码。它对于我生成的大多数 JAR 文件都运行良好,但我有一个运行不正常,并出现一个奇怪的错误:
>> s = javaObject('com.example.test.hdf5.Test1');
??? Error using ==> javaObject
No constructor with appropriate signature exists
in Java class com.example.test.hdf5.Test1
即使这是我的类,并且它有一个常规的旧无参数构造函数:
package com.example.test.hdf5;
import ncsa.hdf.hdf5lib.H5;
import ncsa.hdf.hdf5lib.HDF5Constants;
import ncsa.hdf.hdf5lib.exceptions.HDF5LibraryException;
import ncsa.hdf.object.FileFormat;
import ncsa.hdf.object.h5.H5File;
public class Test1 {
public Test1 () {}
public static void main(String args[])
{
Test1 test = new Test1();
if (args.length < 2)
{
}
else if ("h5file".equals(args[0]))
{
test.testH5File(args[1]);
}
else if ("h5f".equals(args[0]))
{
test.testH5F(args[1]);
}
}
public void testH5File(String filename) {
H5File file;
try
{
file = (H5File) new H5File().createFile(
filename, FileFormat.FILE_CREATE_OPEN);
file.close();
System.out.println("Success!");
}
catch (Exception e)
{
throw new RuntimeException(e);
}
}
public void testH5F(String filename) {
try {
int id = H5.H5Fopen(filename,
HDF5Constants.H5F_ACC_RDONLY, HDF5Constants.H5P_DEFAULT);
H5.H5Fclose(id);
System.out.println("Success!");
}
catch (HDF5LibraryException e) {
throw new RuntimeException(e);
}
catch (NullPointerException e) {
throw new RuntimeException(e);
}
}
}
同一包 + jar 文件中生成的另一个文件工作正常:
package com.example.test.hdf5;
public class Test3 {
public Test3() {}
private int x=0;
public int foo() { return ++this.x; }
}
我想知道是否有什么东西通过导入可能不兼容 1.5 的库而破坏了编译器的 1.5 性。
更新:我的 Test1 和 Test3 类都是 1.5(根据
javap -v
,主要=0,次要=49)。我添加了一个 Test2.java,它与 Test1 完全相同,但方法正文被注释掉,因此它具有相同的签名。我用 javap -s
得到以下信息:
C:\proj\java\test-hdf5\dist>javap -s -classpath test-hdf5.jar com.example.test.hdf5.Test1
Compiled from "Test1.java"
public class com.example.test.hdf5.Test1 extends java.lang.Object{
public com.example.test.hdf5.Test1();
Signature: ()V
public static void main(java.lang.String[]);
Signature: ([Ljava/lang/String;)V
public void testH5File(java.lang.String);
Signature: (Ljava/lang/String;)V
public void testH5F(java.lang.String);
Signature: (Ljava/lang/String;)V
}
C:\proj\java\test-hdf5\dist>javap -s -classpath test-hdf5.jar com.example.test.hdf5.Test2
Compiled from "Test2.java"
public class com.example.test.hdf5.Test2 extends java.lang.Object{
public com.example.test.hdf5.Test2();
Signature: ()V
public static void main(java.lang.String[]);
Signature: ([Ljava/lang/String;)V
public void testH5File(java.lang.String);
Signature: (Ljava/lang/String;)V
public void testH5F(java.lang.String);
Signature: (Ljava/lang/String;)V
}
C:\proj\java\test-hdf5\dist>javap -s -classpath test-hdf5.jar com.example.test.hdf5.Test3
Compiled from "Test3.java"
public class com.example.test.hdf5.Test3 extends java.lang.Object{
public com.example.test.hdf5.Test3();
Signature: ()V
public int foo();
Signature: ()I
}
我猜 HDF5 库 JHDF5.jar 中发生了一些非常奇怪的事情,导致 MATLAB 拒绝我的 Test1 类。
更新 2 >:( >:( >:( JHDF5.jar 文件的版本为 50 (JRE1.6),所以这可能是导致我失败的原因。Phooey to Matlab 没有产生有意义的错误消息,Phooey使用 JRE1.6 而不是 1.5 或更早版本进行编译;我非常怀疑他们是否使用了 1.6 的任何功能,我将提交一份错误报告。
javap -v <classname>
。这将输出类似的内容
minor version: 0
major version: 49
主要版本49是Java平台版本1.5(48是1.4,50是1.6)
methodsview('com.example.test.hdf5.Test1')
看清楚 Matlab 认为你的构造函数期望什么。
Test1
进行了任何修改?如果是这样,您可能必须使用CLEAR 命令:
clear java
来自 CLEAR 文档:
修改 Java 动态类路径上的任何文件后发出
clear java
命令。
本网站表明
通常,您不需要使用 javaObject。请改用默认的 MATLAB 语法来实例化 Java 类。对于上述情况使用 javaObject。因此,如果您知道要创建的类,则可以使用构造函数语法,而不是使用反射创建实例的 javaObject:
s = com.example.test.hdf5.Test1()
这个有用吗?