在责任链模式里,很多对象由每一个对象对其下家的引用而连接起来形成一条链,请求在这个链上传递,直到链上的某一个对象决定处理此请求,发出这个请求的客户端并不知道链上的哪一个对象最终处理这个请求,这使得系统可以在不影响客户端的情况下动态地重新组织链和分配责任。
责任链模式就是这种“推卸”责任的模式,你的问题在我这里能解决我就解决,不行就把你推给另一个对象。至于到底谁解决了这个问题了呢?我管呢!
责任链模式结构:
抽象处理者角色:定义出一个处理请求的接口,还可以定义一个方法,以设定和返回对下家的引用
具体处理者角色:具体处理者接到请求后,可以选择将请求处理掉,或者将请求传给下家
package Responsibility_Chain;
interface Chain {
public abstract void addChain(Chain c);
public abstract void sendToChain(String mesg);
public abstract Chain getChain();
}
class Manager implements Chain {
private Chain nextChain = null;
private String responsibility = "Get Project";;
public Manager() {
}
public void addChain(Chain c) {
nextChain = c;
}
public Chain getChain() {
return nextChain;
}
public void sendToChain(String mesg) {
if(mesg.equals(responsibility)) {
System.out.println("A manager --> Get a Project");
} else {
if(nextChain != null) {
nextChain.sendToChain(mesg);
}
}
}
}
class ProjectManager implements Chain {
private Chain nextChain = null;
private String responsibility = "Design";
public ProjectManager() {
}
public void addChain(Chain c) {
nextChain = c;
}
public Chain getChain() {
return nextChain;
}
public void sendToChain(String mesg) {
if(mesg.equals(responsibility)) {
System.out.println("A PM --> Design");
} else {
if(nextChain != null) {
nextChain.sendToChain(mesg);
}
}
}
}
class Others implements Chain {
private Chain nextChain = null;
private String responsibility = "";
public Others() {
}
public void addChain(Chain c) {
nextChain = c;
}
public Chain getChain() {
return nextChain;
}
public void sendToChain(String mesg) {
System.out.println("No one can handle --> " + mesg);
}
}
public class Responsibility_Chain_Test {
public static void main(String[] args) {
Manager aManager = new Manager();
ProjectManager aPM = new ProjectManager();
Others others = new Others();
aManager.addChain(aPM);
aPM.addChain(others);
aManager.sendToChain("Get Project");
aManager.sendToChain("Design");
aManager.sendToChain("Coding");
aManager.sendToChain("Test");
aManager.sendToChain("Kill La Deng !");
}
}
把自己能解决的自己解决掉,自己不能解决的交给其它去解决,就这样一个传一个,不管最终谁解决了这个问题,降低耦合,
转载:http://www.cnblogs.com/jinzhengquan/archive/2011/01/14/1935898.html