美文网首页
动态代理和静态代理的比较

动态代理和静态代理的比较

作者: shuixingge | 来源:发表于2016-07-11 17:11 被阅读1056次

    1 Proxy类的代码量被固定下来,不会因为业务的逐渐庞大而庞大;因为如果是静态代理的话,随着委托类方法数量越来越多,代理类的代码量是十分庞大的。所以引入动态代理来解决此类问题。
    2 解耦,通过参数就可以判断真实类,不需要事先实例化,更加灵活多变;
    3 可以实现AOP编程,实际上静态代理也可以实现,总的来说,AOP可以算作是代理模式的一个典型应用;(不理解)

    1 接口
    public interface Subject   
    {   
      public void doSomething();   
    }
    
    2 委托类
    
    public class RealSubject implements Subject   
    {   
      public void doSomething()   
      {   
        System.out.println( "call doSomething()" );   
      }   
    } 
    
    3 代理类
    public class SubjectProxy implements Subject
    {
      Subject subimpl = new RealSubject();
      public void doSomething()
      {
         subimpl.doSomething();
      }
    }
    
    4 使用
    public class TestProxy 
    {
       public static void main(String args[])
       {
           Subject sub = new SubjectProxy();
           sub.doSomething();
       }
    }
    

    动态代理

    1 接口
    public interface Subject   
    {   
      public void doSomething();   
    }
    
    2 委托类
    public class RealSubject implements Subject   
    {   
      public void doSomething()   
      {   
        System.out.println( "call doSomething()" );   
      }   
    }  
    
    3 InvocationHandler
    import java.lang.reflect.InvocationHandler;  
    import java.lang.reflect.Method;  
    import java.lang.reflect.Proxy;  
    
    public class ProxyHandler implements InvocationHandler
    {
        private Object tar;
    
        //绑定委托对象,并返回代理类
        public Object bind(Object tar)
        {
            this.tar = tar;
            //绑定该类实现的所有接口,取得代理类 
            return Proxy.newProxyInstance(tar.getClass().getClassLoader(),
                                          tar.getClass().getInterfaces(),
                                          this);
        }    
    
        public Object invoke(Object proxy , Method method , Object[] args)throws Throwable
        {
            Object result = null;
            //这里就可以进行所谓的AOP编程了
            //在调用具体函数方法前,执行功能处理
            result = method.invoke(tar,args);
            //在调用具体函数方法后,执行功能处理
            return result;
        }
    }
    
    4 使用
    public class TestProxy
    {
        public static void main(String args[])
        {
               ProxyHandler proxy = new ProxyHandler();
               //绑定该类实现的所有接口
               Subject sub = (Subject) proxy.bind(new RealSubject());
               sub.doSomething();
        }
    }
    
    

    相关文章

      网友评论

          本文标题:动态代理和静态代理的比较

          本文链接:https://www.haomeiwen.com/subject/lxdjjttx.html