zoukankan      html  css  js  c++  java
  • 设计模式之依赖倒置原则示例

      我们来写一个关于司机开车的示例,假设我们现在有个司机,可以开车,然后有一辆奔驰,于是就可以让车跑起来。

    public class Driver {
        //    司机职责就是驾驶汽车
        public void drive(Benz benz) {
            benz.run();
        }
    }
    
    public class Benz {
        //    车的作用就是跑
        public void run() {
            System.out.println("奔驰车跑起来了");
        }
    }
    
    public class Client {
        public static void main(String[] args) {
            Driver zhangsan = new Driver();
            Benz benz = new Benz();
            // 张三开车
            zhangsan.drive(benz);
        }
    }

      以上代码就可以让张三把奔驰车开起来,可是这样子就有一个问题,如果现在有一辆宝马:

    public class BMW {
        //    车的作用就是跑
        public void run() {
            System.out.println("宝马车跑起来了");
        }
    }

      我们发现张三并不能让宝马车跑起来,因为Driver依赖Benz太紧,当多了BMW后无法扩展。因此针对接口编程,依赖于抽象而不依赖于具体。如下代码所示:

    public interface IDriver {
        //    司机职责就是驾驶汽车
        public void drive(Icar car);
    }
    
    public class Driver implements IDriver{
        //    司机职责就是驾驶汽车
        public void drive(Icar car) {
            car.run();
        }
    }
    
    public interface Icar {
        //    车的作用就是跑
        public void run();
    }
    
    public class Benz implements Icar {
        //    车的作用就是跑
        public void run() {
            System.out.println("奔驰车跑起来了");
        }
    }
    
    public class BMW implements Icar {
        //    车的作用就是跑
        public void run() {
            System.out.println("宝马车跑起来了");
        }
    }
    
    public class Client {
        public static void main(String[] args) {
            IDriver zhangsan = new Driver();
            Benz benz = new Benz();
            zhangsan.drive(benz);
    
            BMW bmw = new BMW();
            zhangsan.drive(bmw);
        }
    }

      这样张三就直接开走了奔驰和宝马,要是接下来再来一辆奥迪,那么原有的所有代码都无需改动,只用添加一辆奥迪的车即可。

  • 相关阅读:
    LeetCode 1032. Stream of Characters
    LeetCode 872. Leaf-Similar Trees
    LeetCode 715. Range Module
    LeetCode 353. Design Snake Game
    LeetCode 509. Fibonacci Number
    LeetCode 632. Smallest Range Covering Elements from K Lists
    LeetCode 963. Minimum Area Rectangle II
    LeetCode 939. Minimum Area Rectangle
    LeetCode 727. Minimum Window Subsequence
    LeetCode 844. Backspace String Compare
  • 原文地址:https://www.cnblogs.com/jing99/p/12576600.html
Copyright © 2011-2022 走看看