[size=medium]原理很简单,就是使用ClassLoader加载新的类,替换掉旧的对象。
注意最好使用接口,我们只是加载实现类,接口类一直使用旧的ClassLoader,这样就不会存在类型转换的报错。
具体的代码也可以参考我的github:https://github.com/huangyunbin/hot/tree/master
[/size]
注意最好使用接口,我们只是加载实现类,接口类一直使用旧的ClassLoader,这样就不会存在类型转换的报错。
具体的代码也可以参考我的github:https://github.com/huangyunbin/hot/tree/master
[/size]
public class DynamicClassLoader extends ClassLoader {
public Class<?> findClass(byte[] b) throws ClassNotFoundException {
return defineClass(null, b, 0, b.length);
}
}
public interface Target {
String name();
}
public class TargetImpl implements Target {
public String name() {
return "测试1";
}
}
import java.io.File;
import java.io.FileInputStream;
import java.io.IOException;
import java.util.concurrent.TimeUnit;
public class Main {
static Target obj = new TargetImpl();
public static void main(String[] args) throws Exception {
while (true) {
String path = "/Users/bin/Documents/workspace/hot/target/classes/com/eyu/hot/TargetImpl.class";
byte[] b = getBytes(path);
Class c = new DynamicClassLoader().findClass(b);
obj = (Target) c.newInstance();
System.err.println(obj.name());
TimeUnit.SECONDS.sleep(2);
}
}
// 从本地读取文件
private static byte[] getBytes(String filename) throws IOException {
File file = new File(filename);
long len = file.length();
byte raw[] = new byte[(int) len];
FileInputStream fin = new FileInputStream(file);
fin.read(raw);
fin.close();
return raw;
}
}