开闭原则是所有设计原则的基础,它非常重要。用一句话来形容开闭原则就是:软件系统的实现应该对扩展开放,对修改关闭。开闭原则的中心思想就是“我们用抽象构建框架,用实现扩展细节“。
为了更好的解释这个抽象的概念,我们一起来看一个例子,其实是很简单的一个概念。首先我有一个接口,这个接口里有一些方法,如下图所示:
package com.zybank.design.principle.openclose;
public interface Course {
Integer getId();
String getName();
Double getPrice();
}
然后我定义一个类去实现这个接口,如下图所示。
package com.zybank.design.principle.openclose;
public class JavaCourse implements Course {
private Integer id;
private String name;
private Double price;
public JavaCourse(Integer id, String name, Double price) {
this.id = id;
this.name = name;
this.price = price;
}
@Override
public Integer getId() {
return this.id;
}
@Override
public String getName() {
return this.name;
}
@Override
public Double getPrice() {
return this.price;
}
}
我在写一个测试类,代码如下:
package com.zybank.design.principle.openclose;
public class Test {
public static void main(String[] args){
Course iCourse = new JavaCourse(1,"Java课程",300D);
System.out.println("课程ID:"+iCourse.getId());
System.out.println("课程名字:"+iCourse.getName());
System.out.println("课程价格:"+iCourse.getPrice());
}
}
此时的UML类图如下:
到这里一个基本代码写完了。不过新的需求来,我想在双12的时候对Java课程进行打折,怎么办?你不会去接口里添加一个getDiscountCourse()方法吧,然后JavaCourse类还要重写该方法;或者直接去JavaCourse类里修改代码进行打折吧。这样做就违背了开闭原则,我们新的需求不对原有的类或者接口进行修改,我们可以写一个JavaDiscountCourse类继承JavaCourse类,以满足我们的需求,这样我们就很好的遵循了开闭原则。如下图所示:
package com.zybank.design.principle.openclose;
public class JavaDiscountCourse extends JavaCourse {
public JavaDiscountCourse(Integer id, String name, Double price) {
super(id, name, price);
}
@Override
public Double getPrice() {
return super.getPrice()*0.7;
}
}
测试类改写如下:
package com.zybank.design.principle.openclose;
public class Test {
public static void main(String[] args){
//Course iCourse = new JavaCourse(1,"Java课程",300D);
Course iCourse = new JavaDiscountCourse(1,"Java课程",300D);
System.out.println("课程ID:"+iCourse.getId());
System.out.println("课程名字:"+iCourse.getName());
System.out.println("课程价格:"+iCourse.getPrice());
}
}
这样UML类图结果如下:
输入的结果如下:
这样我们就通过代码理解了开闭原则。是不是很简单,希望我们在系统的开发过程中多多思考,面对不同的业务场景灵活运用。