今天,我只是试着用编译的Java类文件中的操作码玩一点点。插入后
iinc 1,1
Java虚拟机的响应是:
Exception in thread "main" java.lang.ClassFormatError: Truncated class file
at java.lang.ClassLoader.defineClass1(Native Method)
at java.lang.ClassLoader.defineClassCond(ClassLoader.java:632)
at java.lang.ClassLoader.defineClass(ClassLoader.java:616)
at java.security.SecureClassLoader.defineClass(SecureClassLoader.java:141)
at java.net.URLClassLoader.defineClass(URLClassLoader.java:283)
at java.net.URLClassLoader.access$000(URLClassLoader.java:58)
at java.net.URLClassLoader$1.run(URLClassLoader.java:197)
at java.security.AccessController.doPrivileged(Native Method)
at java.net.URLClassLoader.findClass(URLClassLoader.java:190)
at java.lang.ClassLoader.loadClass(ClassLoader.java:307)
at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:301)
at java.lang.ClassLoader.loadClass(ClassLoader.java:248)
Could not find the main class: Test. Program will exit.
这是我的示例源代码:
public class Test {
public static void main(String[] args) {
int i = 5;
i++;
i++;
i++;
System.out.println("Number: " + i + "\n");
}
}
对于操作数,增量的操作码是0x84+2字节。
结果类文件中只有一个部分,其中包含0x84:
[..] 8401 0184 0101 8401 01[..]
所以我把它翻译成:
iinc 1,1
iinc 1,1
iinc 1,1
对应于我的i++;i++;i++;
然后,我尝试只追加840101来再次增加变量,但这不起作用,导致了ClassFormatError。
类文件是否有类似校验和的内容?
我在
http://java.sun.com/docs/books/jvms/second_edition/html/ClassFile.doc.html
但是找不到任何指向某个字节的类文件或其他东西。我也不明白为什么错误是“截断类文件”,因为我确实附加了一些内容:—)
我知道直接编辑类文件不是一个好主意,但我只是对这里的VM内部感兴趣。