分类 技术志 下的文章

开放与封闭

敏捷设计最基本原则:“开放封闭原则(OCP,Open-Close Principle)”

* 回顾SRP
在开始谈OCP之前,我们还是简单回顾一下Bob大叔在其书中所论述的敏捷设计的第一个原则“单一职责原则(SRP,Single Responsibility Principle)”。

Bob大叔在其书中将职责理解为“变化的原因”。一般当需求变化时,该变化就会反映为类的职责的变化。按书中所述“如果一个类的职责过多,会使职责间产生耦合,一个职责的变化可能会削弱或抑制另一个类完成其他职责的能力,导致该设计的脆弱性。”根据这点论述得出结论:“就一个类而言,应该仅有一个引起它变化的原因”。

简单举个书中的例子理解一下(这里不作详细说明):
//Modem.java
public interface Modem{
    void dial(String portNo);
    void hangup();
    void send(char c);
    void recv();
}
缺点:Modem有两个职责,分别是连接管理和数据通信。经过单一职责分解后==〉
//DataChannel.java
public interface DataChannel{
    void send(char c);
    void recv();
}
//Connection.java
public interface Connection{
    void dial(String portNo);
    void hangup();
}
//Modem.java
public class Modem implements DateChannel , Connection{
    //…
}

曾经在大学的时候用MFC开发程序,当然现在看起来那些程序的设计很糟糕。其中一个典型的缺点就是类的职责分配不明确,当时我常常在一个界面类中写入业务逻辑代码,比如email处理等等。也看过很多网友的MFC代码,出现此类糟糕设计的还是很多的。

* OCP-Open for extension,Closed for modification

引用书中论述“软件实体(类、模块、函数等等)应该是可以扩展的,但是不可修改”。

如何做到OCP?– 抽象
让A模块依赖一个接口或一个抽象类,这样对A模块的修改可以是Closed的。那么如何对A模块进行扩展呢?我们可以通过扩展那个接口的多种实现或者继承那个抽象基类做到这点。

Template Method模式的应用可以很好的解释上面的论述。
//某一个功能模块A是这样依赖一个抽象类AbsBase的:
void callSomething(AbsBase a){
    a.templateMethod();
}

//AbsBase的定义,一个即开放又封闭的基类。
public abstract class AbsBase{
    public abstract void method1();
    public abstract void method2();
    public void templateMethod(){
        method1();
        method2();
    }
}

下面我们就可以通过AbsBase的子类来扩展功能模块A的行为了
public class DerivedClass extends AbsBase{
    public void method1(){
        //…
    }
    Public void method2(){
        //…
    }
}

从上面可以看出Template method模式可以帮助我们去OCP。请时刻想着“抽象”这一实现OCP的基本原则。

在看书的过程中,我感觉到有时候不能为了OCP而去OCP,还需考虑实际情况和系统的整体架构。作者在书中也提到“仅对程序中呈现出的频繁变化的那些部分做抽象。拒绝不成熟的抽象和抽象本身一样重要。”

拥抱敏捷

虽说Bob大叔(Robert C.Martin)的《敏捷软件开发–原则、模式与实践》一书在china mainland出版已经有一年之久了,但是我真正专下心看这本书还是在最近。也许敏捷开发思想和我最初脑海中的软件开发思想有些背道而驰,但是现在我正在准备拥抱它。

* 重温经典的“敏捷软件开发宣言”
宣言部分摘录如下:
个体与交互         胜过     过程和工具
可以工作的软件     胜过     面面俱到的文档
客户合作         胜过     合同谈判
响应变化         胜过     遵循计划

* 理解敏捷
敏捷的概念在我理解是“一切从简”但又不失灵活;直面变化,轻松应对。

管理:一份好的计划是能够快速响应变化的计划。
需求:客户极大程度的参与。
设计:简单、简单还是简单。引用书中的话“如果能够使用简单的socket连接,就不去使用ORB或者RMI;如果能够不使用多线程,就别去用它”
编码:结对、test driven和refactoring.
沟通:面对面交谈胜过mail or 文档。
文档:整个团队编写和维护一份短小精悍的系统原理和结构的文档,永远记住代码是唯一没有二义性的产品。

如发现本站页面被黑,比如:挂载广告、挖矿等恶意代码,请朋友们及时联系我。十分感谢! Go语言第一课 Go语言进阶课 AI原生开发工作流实战 Go语言精进之路1 Go语言精进之路2 Go语言第一课 Go语言编程指南
商务合作请联系bigwhite.cn AT aliyun.com

欢迎使用邮件订阅我的博客

输入邮箱订阅本站,只要有新文章发布,就会第一时间发送邮件通知你哦!

这里是 Tony Bai的个人Blog,欢迎访问、订阅和留言! 订阅Feed请点击上面图片

如果您觉得这里的文章对您有帮助,请扫描上方二维码进行捐赠 ,加油后的Tony Bai将会为您呈现更多精彩的文章,谢谢!

如果您希望通过微信捐赠,请用微信客户端扫描下方赞赏码:

如果您希望通过比特币或以太币捐赠,可以扫描下方二维码:

比特币:

以太币:

如果您喜欢通过微信浏览本站内容,可以扫描下方二维码,订阅本站官方微信订阅号“iamtonybai”;点击二维码,可直达本人官方微博主页^_^:
本站Powered by Digital Ocean VPS。
选择Digital Ocean VPS主机,即可获得10美元现金充值,可 免费使用两个月哟! 著名主机提供商Linode 10$优惠码:linode10,在 这里注册即可免费获 得。阿里云推荐码: 1WFZ0V立享9折!


View Tony Bai's profile on LinkedIn
DigitalOcean Referral Badge

文章

评论

  • 正在加载...

分类

标签

归档



View My Stats