在java里面使用动态代理,一般有以下流程
定义接口
public interface ISample{
public void test();
}
定义实现类
public class SampleImple implements ISample{
public void test(){
....
}
}
定义代理类
public class SampleHandler implements InvocationHandler {
public Object invoke(Object proxy, Method method, Object[] args)
throws Throwable {
}
}
应用例子
public class Test {
public static void main(String[] args) {
SampleImple impl = new SampleImple ();
SampleHandler handler = new SampleImple (impl);
ISample sample= (ISample )Proxy.newProxyInstance(impl .getClass().getClassLoader(), impl.getClass().getInterfaces(), handler);
sample.test();
}
}
在上面的sample.test调用时会先调用SampleHandler里面的invoke。其实只要是调用接口里面的方法都会先调用SampleHandler里面的invoke。
下面看看java里面怎么实现的。
在Proxy.java里面的newProxyInstance方法里面,执行getProxyClass函数,这个方法获取接口的所有方法之后,调用byte[] proxyClassFile = ProxyGenerator.generateProxyClass(proxyName, interfaces)产生了特定的二进制文件。这个方法最后调用ProxyMethod.generateMethod为每一个接口方法都增加这个invoke(Object proxy, Method method, Object[] args)方法的调用。
其实在C程序产生执行代码(包括修改程序本身),然后再把执行权交给它的思路,在以前的编程中也有出现,只不过现代的操作系统对代码在堆栈等地方中的运行限制要多些了。windows下面的挂钩行为和java动态代理的思路如出一辙。
程序中思路是相通的,看你怎么在程序中应用。对细节的关注越多,可能解决的方法就会多一些。