• 简单设计 Keep It Simple,Stupid


    读完.NET企业级应用架构设计其中几条心得觉得不错,联想到平时自己的经验确实有道理,于是记录下来,时刻提醒自己。

    若想设计出好的软件,普通的设计原则就够了。你并不需要特别的设计模式,不过若某个问题恰好可以由某个模式解决,那么该模式将成为解决问题的捷径。时至今日,重复发明轮子,绝对不是什么好事。

    模式并不一定是某个问题的终极解决方案,使用模式也不会让你的代码更好,或者执行速度更快。你更不可能冲到客户面前说:“看,我的产品使用了组合模式、一个领域模型、控制反转和策略模式等,因此这个绝对是个完美的软件。正确应用模式只能保证解决问题,对待模式要有一颗平常心,不要话费很大的力气去让设计符合某个模式。

    经过了多年的面向对象设计,我们可以总结出一些软件设计中的心得体会。这些体会每天都在指导着我们,我们也在将这些体会不断地传播给别人。

    • 将逻辑相关的职责分组并组成类型。在分组的过程中,要特别留意组成有明确用途的类型。
    • 为类型中的功能创建简洁灵活的抽象。在这个过程中,两个形容词能说明良好抽象的特征:清爽的和有弹性的。
    • 在实现具体类型时,注意分离关注点——即谁应该做什么,并确保每个角色都仅有一个类型来扮演,且每个类型仅完成最少的工作。这样做并不是因为懒惰,而是因为力图简单和高效。

    对于简单,无论怎样强调都不过分。尽可能保证简单,但不要再继续简单下去了。这是爱因斯坦曾经说过的一句话,每个软件从业人员都应该牢记于心。

    简单是一切之本,这句话也叫做Keep It Simple,Stupid,这个理念出现在很多原则以及软件设计文章中。比较流行的原则有如下几条。

    • 不要重复你自己:指降低应用程序中的重复,且建议对于同样的信息,仅在一个位置存放。
    • 一次且仅一次:指降低同一个应用程序中编写同样代码次数。
    • 你不会用到它:指仅当不可避免需要且没有其他解决办法时,再向程序中添加功能。

    我们经常喜欢将“简单是一切之本”这个概念与人们在法庭上的权利相比:你所写下的所有东西都将成为调试过程中的障碍。不仅如此,这些东西也会用在每次你与客户之间的会议上,且对你不利

    软件可以正常工作的概率与其所需要的代码行数成反比。

    Bug出现的几率与正在查看该软件的人数及这些人的重要程度成正比。

    专家就是那些最后一刻赶到,陪众人一起挨骂的人。

  • 相关阅读:
    .gitignore不生效-git上传忽略解决方案的配置文件
    JAVA
    Java
    python-函数基础01
    Java常见数据结构
    分代垃圾回收机制及垃圾回收算法
    设计模式【9】------>观察者模式
    设计模式【8】------>策略模式
    设计模式【7】------>原型模式
    设计模式【6】------>外观模式
  • 原文地址:https://www.cnblogs.com/luoht/p/2520426.html
Copyright © 2020-2023  润新知