什么是好的软件设计?

评价设计好坏标准的重要性

软件设计于软件开发人员就像文章大纲于作家的关系。一个好的设计,是整个项目顺利完成的保障。追求好的设计,也是每一个软件开发人员的追求。为了学习到好的设计,我们发明(发现)了设计模式,将优秀的设计提炼了出来,后来人照猫画虎就可以了。但在实践中,还是有很多时候迷茫,也有一些东施效颦,不知道如何灵活应用,不知道如何取舍。
为什么会这样?本质上是我们对于如何评价一个设计的好坏还没有建立具体的标准。假如,我们评价哪一种握筷子方式更好,而标准就是是否能够夹起来嫩豆腐,那么直接对比一个握法是否能够夹起来豆腐就好了,如果没有标准,那么就会各有各的道理,也许还有人说这种握法是某名人发明的,所以才是更好的,出现很多无意义的争论。只有确定了评价标准,才能进行更量化的设计优劣比较。

软件设计好坏的几个评价标准

  1. 是否能够完成预期的功能;
  2. 是否能够应对潜在的变更;
  3. 是否有很好的可读、可维护性;
  4. 是否具有很好的可测试性;
  5. 是否具有良好的可移植性;
  6. 异常发生后,是否具有良好的追踪、调试性;
  7. 是否在问题领域有非常好的抽象性,具备可复用性;

是否能够完成预期的功能

如果一个设计不能做到需求描述的功能或非功能要求,那么要它何用?在实践种,就需要对项目的需求进行确认,如果需求还没有完全确认,那么这个标准也就没了意义。

是否能够应对潜在的变更

变更是软件开发种一定会出现的事情,变更只能通过管理、工具等手段减少,但不会被消灭。所以,设计在一定程度上就要对可能的变更进行预防。为了对变更进行预防,可以将变更分类,有些是很严重的功能变更,有些是视图变更,有些是操作变更,不同的变更可以进行不同的预防设计。

是否有很好的可读、可维护性

设计最终需要被实现,被维护。可读、可维护对于一个长期项目来说是非常重要的一个属性。对于一个一次性的定制项目,也应该尽量保证可读、可维护性,因为实践证明很多一次性的定制项目往往还有后续升级修改要求。

是否具有很好的可测试性

对于软件产品,确保产品的正确性、稳定性是非常重要的,尤其是对于一些安全关键的软件。测试从一定程序上是开发设计的一部分,只有在设计种考虑了最终产品的可测性,才能在设计种对这种可测性进行设计体现。

是否具有良好的可移植性

这个在有些项目中是一个非常重要的标准项,但有些项目对可移植性没有太多要求,但可移植性无论如何都可以作为设计好坏评价的标准之一。

异常发生后,是否具有良好的追踪、调试性

软件产品一定有BUG存在。当产品发布后,可能偶然发生了一个BUG,这个设计是否能够提供一些BUG解决的辅助方式、数据。

是否在问题领域有非常好的抽象性,具备可复用性

一个软件产品,往往涉及很多模块,真正与本项目最为关系密切的算法,也许只有几千行,其余都是围绕该算法来提供支撑,包括文件读写、视图交互、图形展示等等。将不同模块,甚至整个应用进行抽象,脱离了具体领域,就能被更多项目使用。完成同样功能的设计,产生更好可复用模块的设计往往可维护性也会更好。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,997评论 6 502
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,603评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 163,359评论 0 353
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,309评论 1 292
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,346评论 6 390
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,258评论 1 300
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,122评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,970评论 0 275
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,403评论 1 313
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,596评论 3 334
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,769评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,464评论 5 344
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,075评论 3 327
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,705评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,848评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,831评论 2 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,678评论 2 354

推荐阅读更多精彩内容