技术开发 频道

由模式谈面向对象的基本原则之单一职责原则

【IT168 技术文章】

    所谓单一职责原则,就是就一个类而言,应该仅有一个引起它的变化的原因。换句话说,一个类的功能要单一,只做与它相关的事情。

    这个原则是最简单、最容易理解,却是最不容易做到的事情。这个原则的道理谁都理解,可是在实践中呢?

    我们来看一个例子:

    if(action.equals("load")&&tab.equals("1")){

    request.setAttribute("tabId",tab);

    form.set("tabId",tab);

    speciManager.loadIncrement(actionForm, request, tab);

    }

    if(action.equals("Save")&&tab.equals("1")){

    System.out.println("inter increment save action");

    ……

    request.setAttribute("tabId",tab);

    }

    if(action.equals("load")&&tab.equals("2")){

    request.setAttribute("tabId",tab);

    form.set("tabId",tab);

    speciManager.loadMeasureMent(actionForm, request, tab);

    }

    if(action.equals("Save")&&tab.equals("2")){

    ……

    System.out.println("inter increment save action");

    speciManager.loadIncrement(actionForm, request, tab);

    form.set("tabId",tab);

    request.setAttribute("tabId",tab);

    }

    一看就知道这个类做了太多的工作,它既要load一个tab为1的页面和一个tab为2的页面;又要save一个tab为1页面和一个tab为2的页面。这个类的代码我只截取了里面很少的一部分,绝大部分的代码我都省略掉了。这段代码写到最后是越来越混乱,直到最后失败。

    对照着这个例子,我们再来分析一下为什么要遵守单一职责愿则:

    第一、有助于我们分析和编码的思路的清晰。当你的代码里有了三层或以上的if语句或for语句的嵌套的时候,你不要跟我说,你已经把问题分析得很清楚了。多层嵌套的if或for语句只能说明你还没有把问题分析清楚。

    第二、使我们的编码、测试和维护变得简单。

    第三、将一个个复杂的问题简单化以后,易于代码的重用。当你的代码的多个功能搅和在一起的时候,你是没办法考虑代码的重用的,因为你的每一处代码都有不同。

    第四、易于系统的扩展。

 

0
相关文章