开放与封闭

敏捷设计最基本原则:“开放封闭原则(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,还需考虑实际情况和系统的整体架构。作者在书中也提到“仅对程序中呈现出的频繁变化的那些部分做抽象。拒绝不成熟的抽象和抽象本身一样重要。”

另一种“所见即所得”

最近一段时间,看了很多前沿性的资料,发觉在头脑中形成了很多“思维”的孤岛,这些孤岛很无序,我甚至不知道它们是什么时候的出现的,好像一夜间都浮出了“海平面”,我很难将它们连接起来。本篇blog中我想说的也是我一个思维孤岛的展现。

“What you see is what you get”-WYSIWYG
提到“所见即所得”我们就不能不提到它的发明人Charles Simonyi

20世纪70年代作为Xerox公司设在 Palo Alto 的研究中心的一名科学家,Simonyi发明了第一个文字处理软件Bravo, 它在屏幕上准确显示出文件打印的效果,即通常所说的“所见即所得”(WYSIWYG)。后来,Simonyi加入了微软。在微软,他是公司的主要设计者,领导了Word和Excel的研发。现在的Simonyi已离开微软,创办了自己的公司Intentional Software(意图软件)。Simonyi已经足够富有,在最新的福布斯富豪排行榜上他名列第209,驱使他的动力是他的梦想。

Simonyi曾说:
- “软件要像PowerPoint演示那样容易编辑”
- “让代码看起来象设计”
- Simonyi 描述生成程序的新模型时说“它看起来很像PowerPoint的调色板,任何人都可用它制作幻灯片,把文本、图表或图像粘贴到一个直观的但又是虚拟的工作空间的不同位置”

“What you design is what you get”- WYDIWYG
另一种“所见即所得”- “所设计即所得”,不知道这样概括是否得当,也许我的理解只能到达这个地步,我停留在我的“思维”孤岛上,我的目光还到达不了太远的地方。

自己也很难详细阐述我的理解,在见识了了诸如LOP(Language Oriented Programming,面向语言编程)、DSL(Domain Specific Language,领域专用语言)和MDA(Model Driven Architecture, 模型驱动构架)等等或被捧为“银弹”或被讥讽为“吹嘘”的种种概念后,我突然觉得也许我们现阶段想要的可能就是这个“WYDIWYG”,也许还不全是它。

也许在未来还有“What you require is what you get”,那种直接将需求转变为可运行的软件,在目前看来还是遥不可及的。

如发现本站页面被黑,比如:挂载广告、挖矿等恶意代码,请朋友们及时联系我。十分感谢! Go语言第一课 Go语言精进之路1 Go语言精进之路2 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