• 责任链模式


    在责任链模式里,很多对象由每一个对象对其下家的引用而连接起来形成一条链,请求在这个链上传递,直到链上的某一个对象决定处理此请求,发出这个请求的客户端并不知道链上的哪一个对象最终处理这个请求,这使得系统可以在不影响客户端的情况下动态地重新组织链和分配责任。

     

    责任链模式结构:


    抽象处理者角色:定义出一个处理请求的接口,还可以定义一个方法,以设定和返回对下家的引用

    具体处理者角色:具体处理者接到请求后,可以选择将请求处理掉,或者将请求传给下家

     

    public interface Chain {
        public abstract void addChain(Chain c);
        public abstract void sendToChain(String mesg);
        public abstract Chain getChain();
    }

    public 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);
                }
            }
        }
       
    }

    public 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);
                }
            }
        }
      
    }
    public 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 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 !");
        }
    }
            
    把自己能解决的自己解决掉,自己不能解决的交给其它去解决,就这样一个传一个,不管最终谁解决了这个问题,降低耦合,

  • 相关阅读:
    vector详解
    笔记
    积木大赛
    codevs 1086 栈(Catalan数)
    不要把球传我
    同余方程 (codevs1200)
    最小集合
    数的计算
    产生数
    逃跑的拉尔夫
  • 原文地址:https://www.cnblogs.com/jinzhengquan/p/1935898.html
Copyright © 2020-2023  润新知