设计模式的学习

很多同学都是通过阅读些书来学习设计模式,学习各种模式的代码结构或一些不切实际的实用场景,很快忘记,或理解不够,在工作中误用或滥用。
下面我总结了一个很学习设计模式的方法。

重点

设计模式的主要思想其实很简单,就是:测试驱动开发。测试先行。意思是:先写测试代码,再去实现代码。
所以先写单元测试是很重要的,因为选用什么设计模式,不是容易就决定的。还是根据业务场景去决定的。而且业务需求随时都变
化。所以你的代码要经受得住各种变化。设计模式跟着需求变化而变化。这就是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);
    }

}