本人最近有写这样一个功能,根据Excel表中列的数量来动态增长实体类和数据库中的列,如果出现一个问题,类在运行时被修改后,并重新进行编译成了class文件,不知道如何把修改后的类加载到内存中,试了两种方法代码如下
1.无效,加载的始终还是程序运行没有被修改的类。
Class<?> clzz = null;
try {
clzz = Class.forName("com.cr.dto.DataCsvLine");
} catch (ClassNotFoundException e) {
e.printStackTrace();
}
Field[] fields = clzz.getDeclaredFields();
Field.setAccessible(fields, true);
2.有效,但是执行速度很慢,每次都要等4~8秒,有很多处调用和这个方法,会拖慢程序运行速度。
public Class loadClass(String packagePath){
Class clzz = null;
String destPath = this.getClass().getResource("/").getPath();
// 使用URLClassLoader加载class到内存
try {
URL[] urls = new URL[] { new URL("file:/" + destPath + "/") };
URLClassLoader cLoader = new URLClassLoader(urls);
clzz = cLoader.loadClass(packagePath);
} catch (MalformedURLException e) {
e.printStackTrace();
} catch (ClassNotFoundException e) {
e.printStackTrace();
}
return clzz;
}
求大神指点,感激不尽。