java静动态代理分析

本文介绍了代理类的概念,通过买糖的例子解释了代理类的作用——在不修改原目标类的情况下进行代码拓展和维护。分别讲解了静态代理和动态代理的实现方式和优缺点。静态代理通过实现相同接口,易于维护,但方法变动时需同步更新,而动态代理利用反射机制,在运行时动态创建,减少了代码重复和维护工作。
摘要由CSDN通过智能技术生成

今天在学习的时候,看到了“代理类这个词”,之前学到这个似懂非懂就直接跳过了,今天重新认真学习一下什么是代理类。

简单来说,代理类是一个类的另一种实现方式,打个比方,我现在是坐着的,我想买一颗糖,我可以自己站起来直接去买也可以让我的朋友帮我去买,虽然方式不同但还是达到了同样的效果。让朋友去买这个方式就是代理类的作用。代理类可以在不更改原目标类的情况下进行代码的拓展和维护。继续用买糖为例子就相当于不用我站起来去买就可以达到买到糖的效果。

其分为静态和动态两种

静态代理类:

静态代理类的实现方式是目标类和代理类都实现同样的接口,它的优点在于易于维护,但是缺点在于如果接口的方法有更改,那么代理类的方法也要更改,造成较大的工作量和代码重复。

下面来举一个例子:

接口:

public interface UserData {
    public void setUserName(String name);
    public void setUserId(long id);
}

目标类:

import android.util.Log;

public class UserDataImpl implements UserData {
    @Override
    public void setUserName(String name) {
  
    }

    @Override
    public void setUserId(long id) {
     
    }
}

代理类:

class UserDataPoxy implements UserData {
    private UserData userData;

    UserDataPoxy(UserData userData) {
        this.userData = userData;
    }

    @Override
    public void setUserName(String name) {
        Log.d("addname", "testData");
        Log.d(name, "testData");
        userData.setUserName(name);
        Log.d("sucess", "testData");
    }

    @Override
    public void setUserId(long id) {

    }

实现类:

public class MainActivity extends AppCompatActivity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        UserData userData = new UserDataPoxy(new UserDataImpl());
        userData.setUserName("111");
    }
}

结果:

动态代理类:

动态代理类需要用到

java.lang.reflect.Proxy;

接口与目标类不变,代理类:

class UserDataPoxy {
    private Object userData;

    UserDataPoxy(Object userData) {
        this.userData = userData;
    }

    Object getIntence() {
        return Proxy.newProxyInstance(userData.getClass().getClassLoader(), userData.getClass().getInterfaces(), new InvocationHandler() {
            @Override
            public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
                Log.d("addname", "testData");
                Object o = method.invoke(userData, args);
                Log.d("sucess", "testData");
                return o;
            }
        });
    }


}

实现类:

public class MainActivity extends AppCompatActivity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        UserData userData = (UserData) new UserDataPoxy(new UserDataImpl()).getIntence();
        userData.setUserName("111");
    }
}

结果:

静态代理与动态代理的区别在于,静态代理是有程序员自己创建或者自己引入的,它会在汇编时shen生成class文件,而动态代理是运用反射机智创建而成的

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值