JAVA设计模式七大原则—— 单一职责原则

JAVA设计模式七大原则—— 单一职责原则
JAVA设计模式七大原则—— 接口隔离原则
JAVA设计模式七大原则—— 依赖倒转原则
JAVA设计模式七大原则—— 里氏替换原则
JAVA设计模式七大原则—— 开闭原则
JAVA设计模式七大原则—— 迪米特法则
JAVA设计模式七大原则—— 合成复用原则
基本介绍
对类来说的,即一个类应该只负责一项职责。如类A负责两个不同职责:职责1,职责2。 当职责1需求变更而改变A时,可能造成职责2执行错误,所以需要将类A的粒度分解为 A1,A2

我们看如下例子
SingleResponsibility1.class

public class SingleResponsibility1 {
	public static void main(String[] args) {
		Vehicle vehicle = new Vehicle();
		vehicle.run("摩托车");
		vehicle.run("汽车");
		vehicle.run("飞机");
	}

}
// 交通工具类
// 方式1
class Vehicle {
	public void run(String vehicle) {
		System.out.println(vehicle + " 在公路上运行....");
	}
}

在方式1 的run方法中,违反了单一职责原则(因为摩托车和汽车可以在公路上运行,而飞机不行)

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

改进后的类
SingleResponsibility2.class

public class SingleResponsibility2 {

	public static void main(String[] args) {
		RoadVehicle roadVehicle = new RoadVehicle();
		roadVehicle.run("摩托车");
		roadVehicle.run("汽车");
		
		AirVehicle airVehicle = new AirVehicle();
		
		airVehicle.run("飞机");
	}

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

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

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

遵守单一职责原则,但是这样做的改动很大,即将类分解,同时修改客户端

解决方案:直接修改Vehicle 类,改动的代码会比较少

改进后的类
SingleResponsibility3.class

public class SingleResponsibility3 {

	public static void main(String[] args) {
		Vehicle2 vehicle2  = new Vehicle2();
		vehicle2.run("汽车");
		vehicle2.runWater("轮船");
		vehicle2.runAir("飞机");
	}

}

class Vehicle2 {
	public void run(String vehicle) {
		//处理
		
		System.out.println(vehicle + " 在公路上运行....");
		
	}
	
	public void runAir(String vehicle) {
		System.out.println(vehicle + " 在天空上运行....");
	}
	
	public void runWater(String vehicle) {
		System.out.println(vehicle + " 在水中行....");
	}
	
	//方法2.
	//..
	
	//...
}

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

单一职责原则注意事项和细节

  1. 降低类的复杂度,一个类只负责一项职责。
  2. 提高类的可读性,可维护性
  3. 降低变更引起的风险
  4. 通常情况下,我们应当遵守单一职责原则,只有逻辑足够简单,才可以在代码级违 反单一职责原则;只有类中方法数量足够少,可以在方法级别保持单一职责原则,(比如上述解决方案三,类中方法数量足够少,如果后面还有很多方法,就不行了)
发布了152 篇原创文章 · 获赞 73 · 访问量 3254

猜你喜欢

转载自blog.csdn.net/qq_44891295/article/details/103959306
今日推荐