很多同学都是通过阅读些书来学习设计模式,学习各种模式的代码结构或一些不切实际的实用场景,很快忘记,或理解不够,在工作中误用或滥用。
下面我总结了一个很学习设计模式的方法。
重点
设计模式的主要思想其实很简单,就是:测试驱动开发。测试先行。意思是:先写测试代码,再去实现代码。
所以先写单元测试是很重要的,因为选用什么设计模式,不是容易就决定的。还是根据业务场景去决定的。而且业务需求随时都变
化。所以你的代码要经受得住各种变化。设计模式跟着需求变化而变化。这就是XP的关键,拥抱变化。那如何确保每次修改后代码
能稳定地运行呢?那就行写好单元测试。尽量覆盖尽量多的测试用例,每次修改完跑一下单元测试。不用管要用什么设计模式。只
要你的代码都能通过,你的代码肯定用了很多设计模式在里面,不然不可能做到拥抱变化(就是解耦)。设计模式的目标就是拥抱变化。
代码示例
如果你不知道什么叫工厂模式。请跑下面单元测试代码,确保此测试代码能通过,说明你已经掌握工厂模式了。
public class PatternDemo {
@Test
/**
* 工厂模式单元测试
*/
public void testShapeFactory() {
ShapeFactory shapeFactory = new ShapeFactory();
//获取 Circle 的对象,并调用它的 draw 方法
Shape shape1 = shapeFactory.getShape("CIRCLE");
//Shape 是否接口,因为不是接口也可以,类或抽象类也可以实现这样的效果。这样违反了依赖倒置的原则。
//行为的抽象选择依赖接口而非类或抽象类。
//下面判断是否为接口。
//写单元测试时是不用写这个测试的。
final boolean isInterface = Shape.class.isInterface();
Assert.assertEquals(true, isInterface);
//调用 Circle 的 draw 方法
String returnStr = shape1.getDrawStr();
Assert.assertEquals("Inside Circle::draw() method.", returnStr);
//获取 Rectangle 的对象,并调用它的 draw 方法
Shape shape2 = shapeFactory.getShape("RECTANGLE");
//调用 Rectangle 的 draw 方法
returnStr = shape2.getDrawStr();
Assert.assertEquals("Inside Rectangle::draw() method.", returnStr);
//获取 Square 的对象,并调用它的 draw 方法
Shape shape3 = shapeFactory.getShape("SQUARE");
//调用 Square 的 draw 方法
returnStr = shape3.getDrawStr();
Assert.assertEquals("Inside Square::draw() method.", returnStr);
}
}