在对设计模式的学习中,首先需要了解、掌握设计模式的七大原则,这样后续对设计模式的学习才能够更加的轻松与透彻。本章用于总结设计模式中的单一职责原则,该原则也是比较容易理解的。

一、基本介绍

对类来说的,即一个类应该只负责一项职责。如类 A 负责两个不同职责:职责 1,职责 2。当职责 1 需求变更而改变 A 时,可能造成职责 2 执行错误,所以需要将类 A 的粒度分解为 A1,A2。

二、场景应用

2.1 场景一

该场景模拟交通工具使用场景。

目的:模拟交通工具的运输形式。

反例代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
public class SingleExample {

public static void main(String[] args) {

Vehicle vehicle = new Vehicle();
vehicle.run("汽车");
vehicle.run("摩托车");
vehicle.run("飞机");
}
}

class Vehicle {
public void run(String vehicle) {
System.out.println(vehicle + "在公路上运行");
}
}

输出:

1
2
3
汽车在公路上运行
摩托车在公路上运行
飞机在公路上运行

该方式run方法中,违反了单一职责原则(飞机也在公路上跑了)。

解决方案:根据不同的交通工具运行方法不同,分解成不同类即可。

修改代码一
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
public class SingleExample02 {
public static void main(String[] args) {

RoadVehicle roadVehicle = new RoadVehicle();
roadVehicle.run("汽车");
WaterVehicle waterVehicle = new WaterVehicle();
waterVehicle.run("轮船");
AirVehicle airVehicle = new AirVehicle();
airVehicle.run("飞机");

}
}

class RoadVehicle {
public void run(String vehicle) {
System.out.println(vehicle + "公路运行");
}
}

class WaterVehicle {
public void run(String vehicle) {
System.out.println(vehicle + "水中运行");
}
}

class AirVehicle {
public void run(String vehicle) {
System.out.println(vehicle + "天空运行");
}
}

输出:

1
2
3
汽车公路运行
轮船水中运行
飞机天空运行

该方案严格遵守单一职责原则(每个类中只负责一项职能),但是这样做改动较大,同时对客户端(Main)也进行了大改动。在功能、业务逻辑较为简单时,我们可以缩小单一职责原则的范围,可以将该职责落在方法上。

修改代码二
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
public class SingleExample {

public static void main(String[] args) {

Vehicle vehicle = new Vehicle();
vehicle.runRoad("汽车");
vehicle.runWater("轮船");
vehicle.runAir("飞机");
}
}

class Vehicle {
public void runRoad(String vehicle) {
// TODO:公路交通的相关逻辑
System.out.println(vehicle + "在公路上运行");
}

public void runWater(String vehicle) {
// TODO:水中交通的相关逻辑
System.out.println(vehicle + "在公路上运行");
}

public void runAir(String vehicle) {
// TODO:空中交通的相关逻辑
System.out.println(vehicle + "在公路上运行");
}
}

这种修改方法没有对原来的类做大的修改,只是增加方法,这里虽然没有在类这个级别上遵守单一职责原则,但是在方法级别上,仍然是遵守单一职责。

三、总结——单一职责原则注意事项和细节

  1. 降低类的复杂度,一个类只负责一项职责
  2. 提高类的可读性,可维护性
  3. 降低变更引起的风险
  4. 通常情况下,我们应当遵守单一职责原则,只有逻辑足够简单,才可以在代码级违反单一职责原则;只有类中方法数量足够少,可以在方法级别保持单一职责原则(例如修改代码二)

Comment