• 设计模式:策略模式


      策略模式:定义了算法族,分别封装起来,让它们之间可以互相替换,此模式让算法的变化独立于使用算法的客户。

      说白了就是将客户和算法分离开来,下面客户就是Duck的具体类,算法就是封装好的飞行行为,呱呱叫行为。让我们直接看代码吧。

      首先创建客户类Duck代码,具体实现类实现抽象类Duck

    public abstract class Duck {
        //声明飞行行为、呱呱叫行为的引用变量
        FlyBehavior flyBehavior;
        QuackBehavior quackBehavior;
        
        public Duck(){
            
        }
        
        public abstract void display();
        
        public void performFly(){
            //委托给行为类
            flyBehavior.fly();
        }
        public void performQuack(){
            quackBehavior.quack();
        }
    }
    
    public class MullardDuck extends Duck{
        
        public MullardDuck(){
            quackBehavior = new Quack();
            flyBehavior = new FlyWithWings();
        }
        
        @Override
        public void display() {
            System.out.println("I am a real Mallard Duck ");
        }
    }

       接着实现算法,即行为类,其中飞行实现类实现抽象类FlyBehavior,呱呱叫也一样

    public interface FlyBehavior {
        public void fly();
    }
    
    public class FlyNoWay implements FlyBehavior{
        @Override
        public void fly(){
            System.out.println("I can't fly!");
        }
    }
    
    public class FlyWithWings implements FlyBehavior{
        @Override
        public void fly() {
            System.out.println("I am flying!");
        }
    }
    
    public interface QuackBehavior {
        public void quack();
    }
    
    public class Quack implements QuackBehavior{
        @Override
        public void quack() {
            System.out.println("Quack");
        }
    }
    
    public class Squeak implements QuackBehavior{
        @Override
        public void quack() {
            System.out.println("Squeak");
        }
    }
    
    public class MuteQuack implements QuackBehavior{
        @Override
        public void quack() {
            System.out.println("<<Silence>>");
        }
    }

      最后我们进行测试

    public class Test {
        public static void main(String[] args) {
            Duck mallard = new MullardDuck();
            mallard.performQuack();
            mallard.performFly();
        }
    }

      运行结果如下:

      

      好了,这就是策略模式了,把客户和算法分离即可。

      下一节:观察者模式

    作者:哀&RT
    出处:博客园哀&RT的技术博客--http://www.cnblogs.com/Tony-Anne/
    您的支持是对博主最大的鼓励,感谢您的认真阅读。
    本文版权归作者所有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。
  • 相关阅读:
    【More Effective C++ 条款4】非必要不提供default constructor
    【More Effective C++ 条款3】最好不要以多态方式处理数组
    【C++】Debug模式和Release模式的区别
    【More Effective C++ 条款2】最好使用C++转型操作符
    【More Effective C++ 条款1】仔细区别pointers和references
    程序崩溃时的堆栈捕捉
    快速排序--来自维基百科
    十六进制转为字符串
    linux那些事
    svnsync备份
  • 原文地址:https://www.cnblogs.com/Tony-Anne/p/6510089.html
Copyright © 2020-2023  润新知