`
xieyj
  • 浏览: 99909 次
  • 性别: Icon_minigender_1
  • 来自: 武汉
社区版块
存档分类
最新评论

java动态代理

阅读更多

   在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动态代理的思路如出一辙。

    程序中思路是相通的,看你怎么在程序中应用。对细节的关注越多,可能解决的方法就会多一些。

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics