开闭原则要求软件实体对扩展开放、对修改关闭,即通过添加新代码而非修改旧代码来应对需求变化。例如,计算图形面积时,应定义Shape接口,让各类如Circle、Rectangle实现自身面积方法,AreaCalculator通过Shape接口计算总面积,新增图形只需新增类实现Shape,无需修改原有类,从而降低耦合、提升可维护性。结合工厂或策略模式可进一步增强扩展性,核心是抽象变化、依赖接口、利用多态。

开闭原则(Open-Closed Principle, OCP)是面向对象设计中的一个核心原则,它指出:一个软件实体(如类、模块、函数)应该对扩展开放,对修改关闭。这意味着在不改动已有代码的前提下,应该能够为系统添加新功能。这样可以减少引入bug的风险,提高代码的可维护性和可复用性。
理解“对扩展开放,对修改关闭”
这句话的核心在于:当需求变化时,我们不是通过修改已有的类来实现新功能,而是通过添加新的类或方法来完成扩展。原有代码保持不变,依然稳定运行。
例如,假设你有一个计算图形面积的程序:
public class AreaCalculator {public double calculateArea(Object shape) {
if (shape instanceof Circle) {
Circle c = (Circle) shape;
return Math.PI * c.radius * c.radius;
} else if (shape instanceof Rectangle) {
Rectangle r = (Rectangle) shape;
return r.width * r.height;
}
throw new IllegalArgumentException("Unknown shape");
}
}
如果要增加三角形,就必须修改这个类,违反了开闭原则。
立即学习“Java免费学习笔记(深入)”;
使用多态实现开闭原则
更好的方式是定义一个公共接口或抽象类,让每个图形自己实现面积计算:
CPWEB企业网站管理系统(以下称CPWEB)是一个基于PHP+Mysql架构的企业网站管理系统。CPWEB 采用模块化方式开发,功能强大灵活易于扩展,并且完全开放源代码,面向大中型站点提供重量级企业网站建设解决方案。CPWEB企业网站管理系统 2.2 Beta 测试版本,仅供测试,不建议使用在正式项目中,否则发生任何的后果自负。
double area();
}
public class Circle implements Shape {
private double radius;
public double area() { return Math.PI * radius * radius; }
}
public class Rectangle implements Shape {
private double width, height;
public double area() { return width * height; }
}
现在计算总面积的逻辑可以依赖于接口:
public class AreaCalculator {public double calculateTotalArea(List
return shapes.stream().mapToDouble(Shape::area).sum();
}
}
当你需要新增三角形时,只需创建一个新的类实现Shape接口,无需修改AreaCalculator或其他已有类。
利用策略模式或工厂模式增强扩展性
在更复杂的场景中,可以结合设计模式进一步强化开闭原则。比如使用工厂模式创建对象,或策略模式切换算法,都能避免在核心逻辑中写死判断分支。
关键点包括:
- 把变化的部分抽象成接口或抽象类
- 通过继承和多态支持行为扩展
- 高层模块依赖抽象,而不是具体实现
- 利用依赖注入或工厂来解耦对象创建
基本上就这些。开闭原则不是完全禁止修改,而是强调尽量通过扩展而非修改来应对变化。在Java中,合理使用接口、抽象类和设计模式,能让代码更容易遵循这一原则。









