定义:为解除请求的发送者和接受者之间耦合,而使多个对象都有机会处理这个请求,将这些对象连成一条链,并沿着这条链传递该请求,直到有一个对象处理它。
类图:
说明:Handler表示抽象传递者,它定义了一个处理请求的接口,并且在Handler中定义了后继对象,其后继对象类型为Handler,可以在Handler中编写代码实现后继链的设置;ConcreteHandler表示具体传递至,处理它所负责的请求,并可以访问链中的下一个对象,当有请求发送过来时,如果能够处理该请求就处理它,否则将请求转发给后继者;Client表示客户类,它向链中的对象提出最初的请求。
优点:
①降低耦合度
②可简化对象间的相互连接
③增强给对象指派职责的灵活性
④增加新的请求处理类很方便
缺点:
①不能保证请求一定被接收
②系统性能将受到一定影响,而且在进行代码调试时不太方便,可能会造成循环调用。
适用环境:
①有多个对象可以处理同一个请求,具体哪个对象处理该请求由运行时刻自动确定。
②在不明确指定接受者的情况下,向多个对象中的一个提交一个请求。
③可动态指定一组对象处理请求。
实例场景:某公司欲开发一个软件系统的在线文档帮助系统,用户可以在任何一个查询环境中输入查询关键字,如果当前查询环境下没有相关内容,则系统会将查询按照一定的顺序转发给其他查询环境。
实例类图:
实例代码:
* 抽象查询请求处理上下文类:抽象传递者
* @author fly
*
*/
abstract class SearchContext {
protected SearchContext successor;
public void setSuccessor(SearchContext successor){
this.successor = successor;
}
public abstract void search(String keyword);
}
/**
* 具体查询请求处理上下文类:具体传递者
* @author fly
*
*/
class JavaSearchContext extends SearchContext{
@Override
public void search(String keyword) {
// TODO Auto-generated method stub
//模拟实现
if(keyword.contains("Java")){
System.out.println("查询关键字 Java!");
}else{
successor.search(keyword);
}
}
}
/**
* 具体查询请求处理上下文类:具体传递者
* @author fly
*
*/
class SQLSearchContext extends SearchContext{
@Override
public void search(String keyword) {
// TODO Auto-generated method stub
//模拟实现
if(keyword.contains("SQL")){
System.out.println("查询关键字 SQL!");
}else{
successor.search(keyword);
}
}
}
/**
* 具体查询请求处理上下文类:具体传递者
* @author fly
*
*/
class UMLSearchContext extends SearchContext{
@Override
public void search(String keyword) {
// TODO Auto-generated method stub
//模拟实现
if(keyword.contains("UML")){
System.out.println("查询关键字 UML!");
}else{
successor.search(keyword);
}
}
}
//客户端测试
public class Client {
public static void main(String[] args) {
SearchContext jContext,sContext,uContext;
jContext = new JavaSearchContext();
sContext = new SQLSearchContext();
uContext = new UMLSearchContext();
jContext.setSuccessor(sContext);
sContext.setSuccessor(uContext);
String keyword = "UML类图绘制疑惑";
jContext.search(keyword);
}
}
//运行结果: