设计模式-职责链+反射

简介: 设计模式-职责链+反射

这次通过再次学习职责联的模式自己也是收获很多,话不多说直接上干货。

1:都知道职责链的模式是需要设置上下级关系的,这就可以用到一些判断当中,而且是多级判断的,所以我们每一个判断的需求都让它生成一个职责这样就不用把那么的if语句搬出来了。

2:反射的思路,我们可以通过在配置文件中把每个职责的反射写好,然后在单独的写一个反射来,这个反射是干什么的,它的value值是刚刚写好的职责的key值,并且排好序,用符号隔开。


这个是配置文件要准备的事情,这个准备好了就可以直接用了,我们在代码中获取配置文件中写好的那个有对应那些职责链key值的,然后进行切割把它放到一个数组中,要知道把这个值获取 后是一个字符串类型,放入数组的这个过程它的顺序就已经排好了,然后我们通过一个循环可以把这些切割好的字符直接放入反射中就能把那些具体的职责类实例化了,然后设置一个集合接收,这个集合就是这些职责类的父类,前面的工作做完以后就是设置这些类的上下级关系的时候了,也是通过循环的过程设置上下级。


上面这些过程都做完了,那么你的职责链的这个模式更加的灵活了,灵活在哪里呢,就在你的配置文件当中,如果我们在后面想要添加一个新的职责判断,那么我们就不需要再去代码中改了,只需要在配置文件中添加一个新的反射,然后在那个有那些职责Key值的反射中修改一下就好,添加或者修改顺序。


如下:


/

    <add key="T_reviseNew" value="CustomerChange.CustomerChangeNew"/>
    <add key="T_reviseOld" value="CustomerChange.CustomerChangeold"/>
    <add key="T_chargeK" value="CustomerChange.charge"/> //这三个是具体的职责类,通过反射实例化
    <add key="num" value="T_reviseOld,T_chargeK,T_reviseNew"/>  //这个是具体职责链的顺序有这个的出现就把被写死的职责顺序又重新活了,通过反射获取value然后进行切割,而且切割好的这个数组就是按照你写好的这个顺序存放的,只需要循环数组然后通过反射实例化具体的类就好,而你的集合存放顺序也是数组的循环顺序。

具体的代码操作:

            List<CustomerChangeG> list = new List<CustomerChangeG>();//声明一个父类型的集合
            string str = AbstractFactory.Factory.achieve("num");//通过反射获取写好的职责链顺序
            string[] sArray = str.Split(',');//切割写好的顺序放入数组
            foreach (string item in sArray)//循环数组把切割好字符串放入反射进行实例化
            {
                list.Add(AbstractFactory.Factory.Dynamic(item));//讲实例化好的职责类放入集合中
            }
            for (int i = 0; i < list.Count; i++)//循环集合
            {
                var item = list[i];//将具体的类放入这个item中
                var item1 = list[0];//获取第一个职责链中第一个职责类
                if (i != list.Count - 1)//判断是不是集合中最后一个类
                {
                    item.SetSuccessor(item = list[i + 1]);//这里设置上下级
                }
                else
                {
                    item1.HandleRequest(endynamic);//执行职责链
                }
            }

最后:职责链的功能很明确,每一个职责都有自己要做的事情,所以用职责链的功能一般是一个连串性的,但是如果我们想添加一个新的职责就会破开开闭原则,但是这个反射的出现就把这个问题解决了,而且以后我们不管添加多少职责都没有问题,又不会更改代码,只需更改配置文件的顺序就行,

相关文章
|
7月前
|
设计模式 Java 应用服务中间件
【设计模式——学习笔记】23种设计模式——职责链/责任链模式(Chain of Responsibility)(原理讲解+应用场景介绍+案例介绍+Java代码实现)
【设计模式——学习笔记】23种设计模式——职责链/责任链模式(Chain of Responsibility)(原理讲解+应用场景介绍+案例介绍+Java代码实现)
77 0
|
应用服务中间件 容器 设计模式
|
23天前
|
设计模式 SQL 算法
设计模式了解哪些,模版模式
设计模式了解哪些,模版模式
21 0
|
2月前
|
设计模式 Java uml
C++设计模式之 依赖注入模式探索
C++设计模式之 依赖注入模式探索
40 0
|
3月前
|
设计模式 前端开发 JavaScript
观察者模式 vs 发布-订阅模式:两种设计模式的对决!
欢迎来到前端入门之旅!这个专栏是为那些对Web开发感兴趣、刚刚开始学习前端的读者们打造的。无论你是初学者还是有一些基础的开发者,我们都会在这里为你提供一个系统而又亲切的学习平台。我们以问答形式更新,为大家呈现精选的前端知识点和最佳实践。通过深入浅出的解释概念,并提供实际案例和练习,让你逐步建立起一个扎实的基础。无论是HTML、CSS、JavaScript还是最新的前端框架和工具,我们都将为你提供丰富的内容和实用技巧,帮助你更好地理解并运用前端开发中的各种技术。
|
19天前
|
设计模式 Java 数据库
小谈设计模式(2)—简单工厂模式
小谈设计模式(2)—简单工厂模式
|
4天前
|
设计模式 消息中间件 Java
Java 设计模式:探索发布-订阅模式的原理与应用
【4月更文挑战第27天】发布-订阅模式是一种消息传递范式,被广泛用于构建松散耦合的系统。在 Java 中,这种模式允许多个对象监听和响应感兴趣的事件。
20 2
|
7天前
|
设计模式 存储 JavaScript
[设计模式Java实现附plantuml源码~创建型] 多态工厂的实现——工厂方法模式
[设计模式Java实现附plantuml源码~创建型] 多态工厂的实现——工厂方法模式