本地方法开发真的是太难了。
比如下面这个简单的字符串拼接
int x=1;
String a="abc";
String b=a+x;
JVM就执行了1200多条指令!如果出了问题(实际上真的出了问题)排查起来非常困难。
其他如反射获取对象类名也是一样。真是开发5分钟,排错两小时!
而且由于前面开发图进度,给自己挖了不少坑,要花费不少时间去前面填坑!
不过好在最后还是凭着耐心,在前几天肝完了(泪目)
进度一 本地方法调用模块开发
完成了本地方法调用模块的开发,注册了部分本地方法,使得反射获取类名和字符串拼接成为可能!
进度二 完善部分模块代码(填坑)
1、受到本地方法注册与执行方式的启发,将JVM指令执行方式也改了,虽然运行速度似乎没有明显提升,但没有那个令人厌烦,动辄上百的switch——case语句啦!
2、优化了对象结构体和创建对象模块,减少了创建对象消耗(使用内存降为原来的30%,时间缩短了50%)
3、改进了newarray(基本类型数组创建),anewarray(引用类型数组创建),multianewarray(多维数组创建)这三条指令,完善了数组类与基本类型类的加载
零号机:能加载类,执行简单的方法
零点五号机:能从jar包读取.class,初步实现GC,优化运行内存,改进调试工具
一号机:支持数组,完善对象方法的调用,修正部分指令,完成字符串池
二号机:完成本地方法开发(现阶段)
三号机:实现异常处理机制(基本完成)
四号机:实现内存管理,垃圾回收,类的验证算法
五号机:实现多线程,JIT等
恩,大体上这样吧
完成三号机后,JVM的开发就大体完成了。
有空闲时间的话就把开发过程补上
******************************************************************
二号机功能展示
主要展示反射和字符串拼接
Java代码如下:
接下来就是执行该程序啦!
在命令提示符下输入虚拟机可执行文件的路径,输入“run”命令和该排序算法主类的类名全程(Alg/BS/BSort)
JVM完整地执行了整个程序,并成功输出了字符串!