惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

T
Threatpost
V
Vulnerabilities – Threatpost
TaoSecurity Blog
TaoSecurity Blog
C
Cybersecurity and Infrastructure Security Agency CISA
P
Proofpoint News Feed
G
GRAHAM CLULEY
S
Securelist
P
Palo Alto Networks Blog
MongoDB | Blog
MongoDB | Blog
A
Arctic Wolf
Threat Intelligence Blog | Flashpoint
Threat Intelligence Blog | Flashpoint
WordPress大学
WordPress大学
Project Zero
Project Zero
T
Threat Research - Cisco Blogs
L
Lohrmann on Cybersecurity
C
Cyber Attacks, Cyber Crime and Cyber Security
F
Fortinet All Blogs
博客园 - 叶小钗
B
Blog RSS Feed
C
Cisco Blogs
Google DeepMind News
Google DeepMind News
cs.CL updates on arXiv.org
cs.CL updates on arXiv.org
Apple Machine Learning Research
Apple Machine Learning Research
G
Google Developers Blog
K
Kaspersky official blog
D
Docker
Latest news
Latest news
Cisco Talos Blog
Cisco Talos Blog
T
Tor Project blog
Cyberwarzone
Cyberwarzone
Security Latest
Security Latest
Cyber Security Advisories - MS-ISAC
Cyber Security Advisories - MS-ISAC
D
Darknet – Hacking Tools, Hacker News & Cyber Security
Spread Privacy
Spread Privacy
Microsoft Azure Blog
Microsoft Azure Blog
C
Check Point Blog
J
Java Code Geeks
Simon Willison's Weblog
Simon Willison's Weblog
T
Tenable Blog
Recent Announcements
Recent Announcements
T
Tailwind CSS Blog
H
Help Net Security
L
LINUX DO - 热门话题
T
The Exploit Database - CXSecurity.com
Jina AI
Jina AI
S
SegmentFault 最新的问题
MyScale Blog
MyScale Blog
NISL@THU
NISL@THU
美团技术团队
腾讯CDC

博客园 - 太白飞仙

.Net网络资源 CI创意的方法与技巧 可控人生核聚变 用c#备份和还原sql server 2000数据库 论文先睹:关于科学的生命哲学的思考 蚂蚁造山的思考 语言争霸VS魔兽争霸 :: IT世界VS魔兽世界 第九章 SQL Server的简单应用 [导入]类型MSN窗体行为的实现(.NET 2.0) - 太白飞仙 - 博客园 [导入]文章藏金阁 [导入]敏捷实验室的一次争论 [导入]Netron研究(四)----"移动和联通"之联通篇 [导入]Netron研究(二)----"容器"登场 [导入]Netron研究(一)----初识 [导入]Netron研究(三)----"移动和联通"之移动篇 [导入]Agile Framework的日志服务 [导入]Agile Framework工作流服务的设计思路 [导入]KISS原则 [导入]WWF工作流引擎的一个奇怪现象 - 太白飞仙 - 博客园
[导入]时刻提防过度设计
太白飞仙 · 2006-01-16 · via 博客园 - 太白飞仙

在整个软件的开发过程中,从需求到设计再到编码,随时都可能会陷入过度设计的陷阱。因为过度设计所造成的损失绝对不仅仅只是多写几段代码,增加了缺陷发生率,提高了维护成本这么简单。过度设计最可怕的是它会分散你的思维,让你有限的精力浪费在不应该或暂时不应该思考的问题上,而那些真正应该在现阶段得到重视和解决的问题却被你忽略了。你以后会为清理因为过度设计造成的垃圾和弥补本来应该思考的问题付出双重代价。

虽然我一再的提醒自己不要过度设计,但是却仍然不断的过度设计,实在是防不胜防。你也许会说,哪有那么多的过度设计?我举个前两天发生的例子:我们在讨论中间层对象实体类应该如何设计的时候,考虑了实体类会如何被XML序列化的问题。这就是一个典型的过度设计,别看这个问题简单,它带来的坏处就有:

  1. 因为需要考虑到如何对XML的序列化,限制了我们对实体类的设计形式,因而无法达到最佳的设计(这会对以后编写程序造成许多许多本来不必要的麻烦)。
  2. 限制了实体类的持久化形式,万一以后我们不用XML进行持久化,那这个XML序列化就是白考虑了。
  3. 浪费了我们的思考时间。

正确的方式应该是完全按照自顶向下的设计原则,在考虑中间层对象的设计的时候,就不要考虑数据层会如何持久化这个对象。真正应该考虑的是这个对象应该如何适应中间层的业务逻辑。至于如何持久化,到设计数据层的时候再去考虑吧。

不要担心到数据层的时候发现对象设计不合理要重新设计。要知道数据持久化是为中间层业务逻辑服务的,而不是反过来。假如后来发现数据层无法方便的对中间层对象持久化,那么你应该做的是修改数据层,即使比较麻烦,而不是去修改中间层。

总结:

软件开发一定要把握好什么是重要的,什么是不重要的;什么应该现在做,什么可以以后做。


文章来源:http://www.agilelabs.cn/blogs/linkin/archive/2006/01/13/534.aspx