代理模式 —— 静态代理模式

本文介绍了使用切面类实现面向接口编程的方法,展示了如何在不违反开闭原则的前提下,将新增功能与目标方法关联。然而,当目标类变化时,切面类的维护成本增加,是其主要缺点。
摘要由CSDN通过智能技术生成
      1. 负责声明新增功能
      2. 代替开发人员完成目标方法与新增功能的调用

目标方法调用

开发人员==>切面类对象==》

新增功能调用

  1. 口号
    1. 一个切面类为一个接口服务
优缺点
  1. 优点
    1. 在不违反开闭原则,不产生重复性编码的情况下,将新增功能与目标方法进行关联
    2. 第一次将代理模式角色进行了清晰划分
    3. 明确一个切面类为一个接口服务的————面向接口编程
  1. 缺点
    1. 后期目标类个数发生变化时,要帮助的目标方法发生变化时,都会导致提供帮助的切面类进行二次维护——————切面类后期维护会过于频繁
演示
接口
public interface BaseService {
    void run();
}
目标类
public class Service1 implements BaseService {
    @Override
    public void run() {
        System.out.println("Service1运行");
    }
}
public class Service2 implements BaseService {
    @Override
    public void run() {
        System.out.println("Service2运行");
    }
}
切面类
public class ServiceAspect {
    private BaseService target;

    /**
     * 输出当前时间
     */
    public void getTime(){
        DateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
        String date = sdf.format(new Date());
        System.out.println("运行结束的时间:" + date);
    }

    /**
     *
     * @param i 区分类的id
     */
    public void invoke(int i){
        if (i == 1) {
            target = new Service1();
        }
        if (i == 2) {
            target = new Service2();
        }
        target.run();
        getTime();
    }
}
测试类
public class ServiceAspectTest {
    @Test
    public void getTimeTest(){
        ServiceAspect serviceAspect = new ServiceAspect();
        serviceAspect.invoke(1);
        /*
        Service1运行
        运行结束的时间:2024-03-27 20:30:20
        * */
        serviceAspect.invoke(2);
        /*
        Service2运行
        运行结束的时间:2024-03-27 20:30:20
        * */
    }
}
  • 3
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值