首页 > 其他分享 >五:设计模式哲学:六大原则

五:设计模式哲学:六大原则

时间:2023-04-30 14:09:56浏览次数:42  
标签:六大 database int void public 哲学 设计模式 data class

设计模式是软件开发中的经典解决方案,指导我们如何设计更优雅、灵活和可维护的代码。为了理解设计模式的核心思想,让我们从这六大原则出发,看看它们如何应用于日常编程中。在这篇文章中,我将为你揭示这些原则的精髓,并通过幽默、有趣的例子和Java代码来展示它们的应用。

1、单一职责原则 (Single Responsibility Principle, SRP)

想象一下,你在办公室里有一个多功能打印机,它可以打印、复印、扫描、发送传真等。然而,当其中一个功能出现问题时,整个设备都无法使用。同样,一个类也应该只负责一项任务,而不是承担过多的职责。这就是单一职责原则的核心。 Java代码示例:

// Bad example
class Employee {
    public void calculateSalary() {
        // Calculate salary
    }

    public void generateReport() {
        // Generate report
    }
}

// Good example
class Employee {
    public void calculateSalary() {
        // Calculate salary
    }
}

class ReportGenerator {
    public void generateReport(Employee employee) {
        // Generate report
    }
}

在错误的例子中,Employee类负责计算薪水和生成报告,这违反了单一职责原则。正确的例子将这两个功能分离到不同的类中,使得每个类都只负责一项任务。

2、开放封闭原则 (Open/Closed Principle, OCP)

开放封闭原则告诉我们,软件实体(类、模块、函数等)应该对扩展开放,对修改封闭。换句话说,我们应该能够在不修改原有代码的基础上,为其添加新的功能。 Java代码示例:

// Bad example
class Rectangle {
    public int width;
    public int height;
}

class AreaCalculator {
    public int calculateArea(Rectangle[] rectangles) {
        int area = 0;
        for (Rectangle rectangle : rectangles) {
            area += rectangle.width * rectangle.height;
        }
        return area;
    }
}

// Good example
abstract class Shape {
    public abstract int calculateArea();
}

class Rectangle extends Shape {
    public int width;
    public int height;

    @Override
    public int calculateArea() {
        return width * height;
    }
}

class Circle extends Shape {
    public int radius;

    @Override
    public int calculateArea() {
        return (int) (Math.PI * radius * radius);
    }
}

class AreaCalculator {
    public int calculateArea(Shape[] shapes) {
        int area = 0;
        for (Shape shape : shapes) {
            area += shape.calculateArea();
        }
        return area;
    }
}

在错误的例子中,如果我们要计算其他形状的面积,就需要修改AreaCalculator类。而在正确的例子中,我们通过引入抽象类Shape来实现开放封闭原则。现在,我们可以添加新的形状类,如Triangle,而无需修改AreaCalculator类。

3、里氏替换原则 (Liskov Substitution Principle, LSP)

里氏替换原则讲的是子类应该能够替换其基类,并且不会改变程序的正确性。换句话说,如果一个类在某个场景下可以使用,那么它的子类也应该适用于同样的场景。 Java代码示例:

class Bird {
    public void fly() {
        // Fly
    }
}

class Penguin extends Bird {
    @Override
    public void fly() {
        throw new UnsupportedOperationException("Penguins can't fly!");
    }
}

// Good example
class Bird {
    public void fly() {
        // Fly
    }
}

class FlightlessBird extends Bird {
    @Override
    public void fly() {
        throw new UnsupportedOperationException("Flightless birds can't fly!");
    }
}

class Penguin extends FlightlessBird {
}

在错误的例子中,Penguin类违反了里氏替换原则,因为它不能像其他鸟类那样飞行。正确的例子引入了一个新的中间类FlightlessBird,使得Penguin类不再违反LSP。

4、接口隔离原则 (Interface Segregation Principle, ISP)

接口隔离原则告诉我们,不应该强迫一个类实现它不需要的接口。换句话说,我们应该将接口划分为更小的、更具体的接口,以满足不同的需求。 Java代码示例:

// Bad example
interface Animal {
    void eat();
    void swim();
    void fly();
}

class Shark implements Animal {
    @Override
    public void eat() {
        // Eat
    }

    @Override
    public void swim() {
        // Swim
    }

    @Override
    public void fly() {
        throw new UnsupportedOperationException("Sharks can't fly!");
    }
}

// Good example
interface Swimmer {
    void swim();
}

interface Eater {
    void eat();
}

interface Flyer {
    void fly();
}

class Shark implements Swimmer, Eater {
    @Override
    public void eat() {
        // Eat
    }

    @Override
    public void swim() {
        // Swim
    }
}

在错误的例子中,Animal接口包含了不相关的方法,迫使Shark实现不需要的fly方法。正确的例子将接口划分为更小的接口,遵循了接口隔离原则。

5、依赖倒置原则 (Dependency Inversion Principle, DIP)

依赖倒置原则要求我们依赖抽象而不是具体的实现。这样可以使得系统更加灵活,易于扩展和修改。 Java代码示例:

// Bad example
class MySQLDatabase {
    public void saveData(String data) {
        // Save data
        // Save data to MySQL database
    }
}

class DataManager {
    private MySQLDatabase database;

    public DataManager(MySQLDatabase database) {
        this.database = database;
    }

    public void saveData(String data) {
        database.saveData(data);
    }
}

// Good example
interface Database {
    void saveData(String data);
}

class MySQLDatabase implements Database {
    @Override
    public void saveData(String data) {
        // Save data to MySQL database
    }
}

class MongoDBDatabase implements Database {
    @Override
    public void saveData(String data) {
        // Save data to MongoDB database
    }
}

class DataManager {
    private Database database;

    public DataManager(Database database) {
        this.database = database;
    }

    public void saveData(String data) {
        database.saveData(data);
    }
}

在错误的例子中,DataManager类依赖于具体的MySQLDatabase实现,这使得代码难以修改和扩展。正确的例子引入了一个Database接口,使得DataManager依赖于抽象而不是具体实现。这样,我们可以轻松地切换到其他数据库,例如MongoDBDatabase。

6、合成复用原则 (Composite Reuse Principle, CRP)

合成复用原则强调通过组合和聚合来实现代码的复用,而不是通过继承。这样可以使得系统更加灵活,降低了类之间的耦合。 Java代码示例:

// Bad example
class Engine {
    public void start() {
        // Start engine
    }
}

class Car extends Engine {
    public void drive() {
        start();
        // Drive
    }
}

// Good example
class Engine {
    public void start() {
        // Start engine
    }
}

class Car {
    private Engine engine;

    public Car(Engine engine) {
        this.engine = engine;
    }

    public void drive() {
        engine.start();
        // Drive
    }
}

在错误的例子中,Car类通过继承Engine来实现复用。然而,这使得代码难以修改和扩展。正确的例子通过组合的方式,将Engine作为一个成员变量,从而遵循了合成复用原则。 通过遵循这些设计模式哲学中的六大原则,我们可以编写出更优雅、灵活和可维护的代码。在实际项目中,我们可能会根据具体情况灵活运用这些原则,以实现最佳的设计。希望这篇文章能帮助你更好地理解设计模式,并在实际编程过程中运用得心应手。

标签:六大,database,int,void,public,哲学,设计模式,data,class
From: https://blog.51cto.com/u_13616584/6237836

相关文章

  • 【模板方法设计模式详解】C/Java/JS/Go/Python/TS不同语言实现
    简介模板方法模式(TemplateMethodPattern)也叫模板模式,是一种行为型模式。它定义了一个抽象公开类,包含基本的算法骨架,而将一些步骤延迟到子类中,模板方法使得子类可以不改变算法的结构,只是重定义该算法的某些特定步骤。不同的子类以不同的方式实现这些抽象方法,从而对剩余的逻辑有......
  • JS 设计模式
    单例模式一个类只有一个实例,并提供一个访问它的全局访问点。1classLoginForm{2constructor(){3this.state='hide'4}5show(){6if(this.state==='show'){7alert('已经显示')8return9......
  • Java设计模式-单例模式
    一、前言单例模式是一种设计模式,它确保一个类只能创建一个实例,并提供一种全局访问这个实例的方式。在Java中,单例模式可以通过多种方式来实现,其中最常见的是使用私有构造函数和静态方法实现二、基本语法在Java中,实现单例模式的方式有多种,其中最常见的实现方式包括以下几种:1、......
  • 设计模式
    第一章软件架构设计原则1.1开闭原则开闭原则的核心思想就是面向抽象编程开闭原则是面向对象编程中的一个设计原则,也被称为OCP原则。它的定义为:软件中的对象(类、模块、函数等)应该对扩展开放,对修改关闭。换句话说,一个软件实体应该通过扩展来实现变化,而不是通过修改已有的代码......
  • 【策略设计模式详解】C/Java/JS/Go/Python/TS不同语言实现
    简介策略模式(StrategyPattern)属于行为型设计模式。将每一个算法封装到具有共同接口的独立类中,根据需要来绑定策略,使得具体实现和策略解耦。当你想使用对象中各种不同的算法变体,使用if...else所带来的复杂和难以维护,可使用策略模式。或者当有许多相同类,它们仅在执行某些行为时......
  • 设计模式-工厂篇(1)
    意图:定义一个用于创建对象的接口,让子类决定实例化哪一个类。FactoryMethod 使一个类的实例化延迟到其子类。适用性:当一个类不知道它所必须创建的对象的类的时候。当一个类希望由它的子类来指定它所创建的对象的时候。当类将创建对象的职责委托给多个帮助子类中的某一个,并且......
  • python的设计模式
    设计模式目录设计模式一、什么是设计模式二、python实现设计模式创建型模式1.单例模式2.工厂模式一、什么是设计模式软件工程中,设计模式是指软件设计问题的推荐方案。设计模式一般是描述如何组织代码和使用最佳实践来解决常见的设计问题。需要记住一点:设计模式是高层次的方案,并......
  • Java设计模式-抽象工厂模式
    简介设计模式是软件设计中的一种常见方法,通过定义一系列通用的解决方案,来解决常见的软件设计问题。其中,抽象工厂模式是一种非常常见的设计模式,它可以帮助我们创建一组相关的对象,而不需要指定具体的实现方式。抽象工厂模式是一种创建型设计模式,它提供了一种方式来创建一组相关的......
  • 设计模式小结
    简单工厂模式将具有相同属性事物用一个抽象基类,里面具有抽象方法来作为父类,然后其他子类通过继承来实现这个基类,通过重写实现基类里面的抽象方法创建一个工厂方法,通过父类变量来策略模式就是在简单工厂模式的基础上,将工厂方法改成策略对象,然后去调用该对象的重写基类的抽象方法单一......
  • 【单例设计模式原理详解】Java/JS/Go/Python/TS不同语言实现
    简介单例模式(SingletonPattern)属于创建型设计模式,这种模式只创建一个单一的类,保证一个类只有一个实例,并提供一个访问该实例的全局节点。当您想控制实例数目,节省系统资源,并不想混用的时候,可以使用单例模式。单例有很多种实现方式,主要分为懒汉和饿汉模式,同时要通过加锁来避免线程......