首先简单介绍一下委派模式的定义:委派模式不属于23种设计模式,主要是负责任务的调配和分配任务,跟代理模式很像,基本上可以看做特殊情况下的静态代理的全权代理,但是代理模式注重过程,委派模式注重结果,委派模式在spring中用的很多,我们spring中DispatcherServlet就是用到了委派模式,他是负责接收请求,处理过程就需要一个调度。例如我们生活中,在公司里面老板接到了一个项目,把这个任务交给了项目经理,项目经理把项目划分为不同的模块,交到不同的人手中。下面的人将完成的进度和结果反馈给项目经理,然后项目经理统一汇报领导。
下面就根据据举的这个例子进行编码来理解
首先创建一个员工接口,里面有一个方法,就是工作
package simple;
/**
* 定义员工接口
* @author lp
*/
public interface Employee {
public void doing(String command);
}
然后分别创建不同的员工A,B来模拟这个场景,现实中肯定有很多,这里简单举例子说明
package simple;
/**
* 员工A
* @author lp
*/
public class EmployeeA implements Employee {
@Override
public void doing(String command) {
System.out.println("我是员工A,我负责业务逻辑,现在开始做"+command+"工作");
}
}
package simple;
/**
* 员工B
* @author lp
*/
public class EmployeeB implements Employee {
@Override
public void doing(String command) {
System.out.println("我是员工B,负责数据处理,现在开始做"+command+"工作");
}
}
然后创建一个类模拟老板,老板里面的构造直接调用领导,所以还要有一个领导类
package simple;
/**
* 定义老板
* @author lp
*/
public class Boss {
public void command(String command,Leader leader){
leader.doing(command);
}
}
领导自己是不做事情的,只负责分发调度
package simple;
import java.util.HashMap;
import java.util.Map;
/**
* 领导
* @author lp
*/
public class Leader implements Employee{
//定义集合是因为会有多个员工,这里只是举例子
private Map<String,Employee>map=new HashMap<>();
public Leader(){
map.put("业务逻辑",new EmployeeA());
map.put("数据处理",new EmployeeB());
}
//项目经理自己不做事情
@Override
public void doing(String command) {
map.get(command).doing(command);
}
}
全部定义完了之后开始测试
package simple;
public class Test {
public static void main(String[] args) {
//客户请求(Boss)、委派者(Leader)、被被委派者(Employee)
//委派者要持有被委派者的引用
//代理模式注重的是过程, 委派模式注重的是结果
//策略模式注重是可扩展(外部扩展),委派模式注重内部的灵活和复用
//委派的核心:就是分发、调度、派遣
//委派模式:就是静态代理和策略模式一种特殊的组合
new Boss().command("业务逻辑",new Leader());
}
}
1068

被折叠的 条评论
为什么被折叠?



