Java静态代理模式

文章介绍了Java静态代理模式的概念,通过明星与经纪人的例子解释了代理模式的作用,即分离特定职责,使得真实角色更加专注。文中提供了代码示例,展示了如何创建接口、真实对象和代理角色,并阐述了代理模式在日志记录等方面的应用。同时,文章提到了静态代理的优缺点以及在SpringAOP中的关联。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Java静态代理模式

为什么要学习代理模式?因为这就是SpringAOP的底层!SpringAOP和SpringMVC面试必问!

  • 什么是代理模式?
    • 就拿明星与经纪人的关系来说,明星就好比被代理类,明星只需要负责唱歌,表演或给粉丝签名等事务,而类似签合同,面谈,计划日程安排等经纪事务都不需要明星个人去做,可以交给其经纪人来代理完成

角色分析

  • 抽象角色:一般会使用接口或者抽象类来解决
  • 真实角色:被代理的角色->房东
  • 代理角色:代理真实角色,代理真实角色后,我们一般会做一些附属操作->中介
  • 客户:访问代理对象的人->租房子的人

请添加图片描述

代码步骤:

1、接口

public interface Rent {
    public  void rent();
}

2、真实对象

//房东
public class Host implements Rent{
    @Override
    public void rent() {
        System.out.println("房东要出租房子");
    }
}

3、代理角色

public class Proxy implements Rent{


    //代理要帮房东租房子,要先认识房东,如果用继承很有局限性,用组合的方式直接把房东拿进来就可以了
    private Host host;

    public Proxy() { //  构造器快捷键command+N
    }

    public Proxy(Host host) {
        this.host = host;
    }

    @Override
    public void rent() {
        seeHouse();
        host.rent();//传给他的是哪个客户,他就帮哪个客户出租房屋
        hetong();
        fare();

    }

    //有一些事情房东不能做,中介可以完成 比如:看房,
    public void seeHouse(){
        System.out.println("中介带你看房");
    }

    public void fare(){
        System.out.println("收中介费");
    }

    public void hetong(){
        System.out.println("签租赁合同");
    }


}

4、客户端访问代理角色

public class Client {
    public static void main(String[] args) {
        Host host = new Host();

        //代理 ,中介帮房东出租房子,但是代理一般会提供一些附属操作,房东只需要安安心心租房子不用管其他的事情,多余的事情交给中介去做
        Proxy proxy = new Proxy(host);

        //租客直接面对的是中介,不用面对房东
        proxy.rent();
    }
}
  • 代理模式的好处:
    • 可以使真实角色的操作更加存粹!不用去关注一些公共的业务
    • 公共业务就交给代理角色,实现了业务的分工!
    • 公共业务发生扩展的时候,方便集中管理!
  • 缺点:
    • 一个真实角色就会产生一个代理角色,代码量会翻倍-开发效率会变低

加深理解静态代理模式

1、抽象对象-接口

public interface UserService {//这是抽象角色,实现增删改查
    public void add();
    public void delete();
    public void update();
    public void query();
}

2、真实对象

//真实对象
public class UserServiceImpl implements UserService{
    @Override
    public void add() {
        System.out.println("增加了一个用户");
    }

    @Override
    public void delete() {
        System.out.println("删除了一个用户");
    }

    @Override
    public void update() {
        System.out.println("修改了一个用户");
    }

    @Override
    public void query() {
        System.out.println("查询了一个用户");
    }
}

3、代理角色-代理人

public class UserServiceProxy implements UserService{//Proxy->代理人

    private UserServiceImpl userService;
    //构造


    public void setUserService(UserServiceImpl userService) {
        this.userService = userService;
    }

    @Override
    public void add() {
        log("add");
        userService.add();
    }

    @Override
    public void delete() {
        log("delete");
        userService.delete();
    }

    @Override
    public void update() {
        log("update");
        userService.update();
    }

    @Override
    public void query() {
        log("query");
         userService.query();
    }

    //加一个日志方法
    public void log(String msg){
        System.out.println("使用了"+msg+"方法");
    }
}

4、客户端访问代理角色-Client 客户

public class Client {//Client->客户,当事人,委托人
    public static void main(String[] args) {
        UserServiceImpl userService = new UserServiceImpl();
//        userService.add();
        UserServiceProxy userServiceProxy = new UserServiceProxy();
        userServiceProxy.setUserService(userService);//代理了真实对象

        userServiceProxy.add();
        userServiceProxy.update();

    }
}


感慨一下:
学习真的是一个越学感觉自己越无知的过程。

### Java静态代理模式概念 Java静态代理是一种设计模式,在这种模式下,客户端并不直接调用实际对象的方法,而是通过一个实现了相同接口的代理类来间接调用。这种方式可以使得在不修改原功能的情况下增加额外的功能逻辑。 ### 静态代理模式实现方式 为了实现静态代理,通常需要定义两个部分: - **接口**:声明业务方法。 - **真实主题角色(被代理的对象)** 和 **代理角色** :两者都需实现相同的接口;其中代理角色持有对真实主题角色实例的引用,并在其基础上扩展或改变行为[^1]。 ### 使用场景 当希望在不影响原有代码的基础上向现有服务添加新特性时,比如日志记录、权限验证等功能增强,此时就可以考虑采用静态代理模式。它适用于那些想要控制访问或者装饰已有组件的情况。 ### 示例代码展示 下面是一个简单的例子展示了如何利用静态代理来进行邮件发送操作前后的处理工作: #### 定义公共接口 `MailService` ```java public interface MailService { void send(); } ``` #### 创建具体的服务实现类 `RealMailServiceImpl` ```java public class RealMailServiceImpl implements MailService { @Override public void send() { System.out.println("真实的 send message : java"); } } ``` #### 构建代理类 `StaticProxyImpl` 此代理也实现了同样的接口并持有一个指向真正服务者的引用以便于调用其内部方法。 ```java public class StaticProxyImpl implements MailService{ private final MailService mailService; public StaticProxyImpl(MailService mailService){ this.mailService = mailService; } @Override public void send(){ // 前置处理 System.out.println("before method send()"); // 调用真正的send方法 mailService.send(); // 后置处理 System.out.println("after method send()"); } } ``` #### 测试静态代理的效果 最后编写一段简单的测试程序来观察效果: ```java public class TestStaticProxy { public static void main(String[] args) { // 初始化真实的角色和服务者 MailService realMailService = new RealMailServiceImpl(); // 将realMailService传入到我们的代理中去 MailService proxy = new StaticProxyImpl(realMailService); // 执行代理的方法 proxy.send(); } } ``` 上述代码将会打印如下信息: ``` before method send() 真实的 send message : java after method send() ``` 这表明已经成功地应用了静态代理模式,在保持原始功能不变的同时增加了前后端的操作。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值