栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

java中动态代理简单理解

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

java中动态代理简单理解

1,Java动态代理相关API
  1. Proxy :专门完成代理的操作类,是所有动态代理类的父类。通过此类为一 个或多个接口动态地生成实现类。

  2. 提供用于创建动态代理类和动态代理对象的静态方法

    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-kS29WBvV-1652275886273)(C:UsersThinkAppDataRoamingTyporatypora-user-images1652274619957.png)]

2,动态代理实现案例
  1. 如何根据加载到内存中的被代理类,动态创建一个代理类及其对象

    class ProxyFactory{
        
        public static Object getProxyInstance(Object obj) {
            MyInvacationHandler myInvacationHandler = new MyInvacationHandler();
            myInvacationHandler.bind(obj);
            return Proxy.newProxyInstance(obj.getClass().getClassLoader(), obj.getClass().getInterfaces(),myInvacationHandler);
        }
    }
    
  2. 当通过代理类的对象调用方法时,如何动态去调用被代理类中对应的同名方法

    class MyInvacationHandler implements InvocationHandler{
        private Object obj;
    
        public void bind(Object obj) {
            this.obj = obj;
        }
    
        HumanUtil humanUtil = new HumanUtil();
    
        
        @Override
        public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
            humanUtil.method1();
            Object invokeValue = method.invoke(obj, args);
            humanUtil.method2();
            return invokeValue;
        }
    }
    
  3. 动态代理案例完整代码

    interface Human{
    
        String getBelif();
    
        void eat(String food);
    }
    
    
    class HumanUtil{
        public  void method1(){
            System.out.println("通用方法1");
        }
    
        public  void method2(){
            System.out.println("通用方法2");
        }
    }
    
    
    class SuperMan implements Human{
        @Override
        public String getBelif() {
            return "I CAN FLY!!!";
        }
    
        @Override
        public void eat(String food) {
            System.out.println("李狗喜欢吃"+food);
        }
    }
    
    
    class ProxyFactory{
        
        public static Object getProxyInstance(Object obj) {
            MyInvacationHandler myInvacationHandler = new MyInvacationHandler();
            myInvacationHandler.bind(obj);
            return Proxy.newProxyInstance(obj.getClass().getClassLoader(), obj.getClass().getInterfaces(),myInvacationHandler);
        }
    }
    
    
    class MyInvacationHandler implements InvocationHandler{
        private Object obj;
    
        public void bind(Object obj) {
            this.obj = obj;
        }
    
        HumanUtil humanUtil = new HumanUtil();
    
        
        @Override
        public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
            humanUtil.method1();
            Object invokeValue = method.invoke(obj, args);
            humanUtil.method2();
            return invokeValue;
        }
    }
    
    
    public class ProxyTest {
        public static void main(String[] args) {
            SuperMan superMan = new SuperMan();
            //代理类的对象
            Human proxyInstance = (Human)ProxyFactory.getProxyInstance(superMan);
            //代理类调用方法时,会自动调用被代理类中的同名方法
            proxyInstance.eat("11111111");
            NikeClothFactory nikeClothFactory = new NikeClothFactory();
            ClothFactory proxyNikeClothFactory = (ClothFactory)ProxyFactory.getProxyInstance(nikeClothFactory);
            proxyNikeClothFactory.produceCloth();
        }
    }
    

    得到的结果如下图:
    **总结:**通过代理类创建的代理对象进行方法的调用,实际是调用的被代理对象的方法(动态调用),通用方法直接写死。

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/877937.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号