一、单一职责原则基本介绍
单一职责原则,从字面上可以看出:一个类只负责一项职责。对类来说,即一个类应该只负责一项职责,如类A负责两个不同职责:职责1、职责2,当职责1需求变更而改变类A时,可能造成职责2执行错误,所以需要将类A的粒度分解为A1、A2。
一个类只有一个引起它变化的原因,那这个类只有一个职责。每一个职责都是变化的一个轴线。如果一个类有一个以上的职责,这些职责就耦合在一起了。这是导致脆弱的设计。当一个职责发生变化时,可能会影响其他的职责。另外,多个职责耦合在一起,会影响复用性。
二、案例讲解
public class SingleResponsibility{
public static void main(String[] args){
Vechicle v = new Vechicle();
v.run("摩托车");
v.run("汽车");
v.run("飞机");
}
}
class Vechicle{
public void run(String vechicle){
System.out.println(vechicle + "在公路上跑....")
}
}
运行的结果为:
分析上面的案例可知,违反了单一职责原则,因为飞机不能在公路上跑。怎样才能解决问题呢?解决的方案非常简单,就是根据交通工具运行方式的不同,分解成不同的类即可。代码如下。
public class SingleResponsibility{
public static void main(String[] args){
RoadVechicle v = new RoadVechicle();
v.run("摩托车");
v.run("汽车");
AirVechicle airVechicle = new AirVechicle();
airVechicle.run("飞机");
}
}
class RoadVechicle{
public void run(String vechicle){
System.out.println(vechicle + "在公路上跑....")
}
}
class AirVechicle{
public void run(String vechicle){
System.out.println(vechicle + "在天上飞....")
}
}
上面的案例遵守了单一职责原则,但是这样做的改动很大,即将类分解,同时修改客户端。我们可以直接修改Vehicle类,改动的代码就会比较少,代码如下所示:
public class SingleResponsibility{
public static void main(String[] args){
Vechicle v = new Vechicle();
v.run("摩托车");
v.run("汽车");
v.fly("飞机");
}
}
class Vechicle{
public void run(String vechicle){
System.out.println(vechicle + "在公路上跑....")
}
public void fly(String vechicle){
System.out.println(vechicle + "在天上飞....")
}
}
这种修改方式,没有对原来的类作很大的修改,只是增加了方法。虽然没有在类这个级别上遵守单一职责原则,但是在方法级别上,仍然遵守单一职责。
三、单一职责注意事项和细节
1)降低类的复杂度,一个类只负责一项职责
2)提高类的可读性,可维护性
3)降低变更带来的风险
4)通常情况下,我们应该遵守单一职责原则,只要逻辑足够简单,才可以在代码级不违反单一职责原则;只有类中方法数量足够小,可以在方法级别保持单一职责原则