Pattern Pathology
来源:互联网 发布:e商网淘宝代发靠谱吗 编辑:程序博客网 时间:2024/06/05 01:58

Pattern Pathology
Chad LaVigne
dESign pATTERnS ARE onE oF THE MoST vAluABlE ToolS available to the software architect. Using patterns allows us to create common solutions that are easier to communicate and understand. They are concepts that are directly associated with good design. This fact can make it very enticing to demonstrate our architectural prowess by throwing a lot of patterns at a proj- ect. If you find yourself trying to shoehorn your favorite patterns into a prob- lem space where they don’t apply, you may be a victim of pattern pathology.
Many projects suffer from this condition. These are the projects where you envision the original architect looking up from the last page in his patterns book, rubbing his hands together and saying, “Now, which one will I use first!?”. This mentality is somewhat akin to that of a developer who begins writing a class with the thought “hmmm, what class should I extend?”. Design patterns are excellent tools for mitigating necessary complexity, but like all tools, they can be misused. Design patterns become a problem when we make them the proverbial hammer with which we must strike every nail. Be careful that your appreciation for patterns doesn’t become an infatuation that has you introducing solutions that are more complicated than they need to be.

Stamping patterns all over a project unnecessarily is over-engineering. Design patterns are not magic and using them doesn’t automatically qualify a solu- tion as good design. They are reusable solutions to recurring problems. They have been discovered and documented by others to help us recognize when we’re looking at a wheel that’s already been invented. It’s our job to identify problems solved by these solutions when they arise and apply design patterns appropriately. Don’t let your desire to exhibit design pattern knowledge cloud your pragmatic vision. Keep your sights focused on designing systems that provide effective business solutions and use patterns to solve the problems they address.
Chad LaVigne is a solutions architect and technical hired gun for Baltimore-based TEKSystems, Inc. He works primarily in the Minneapolis area designing and implementing solutions utilizing Enterprise Java technologies.
- Pattern Pathology
- Pattern Pathology
- In an Age of Images, Teaching Pathology by Hand
- pattern
- pattern
- Pattern
- Pattern
- Pattern
- Pattern
- Pattern
- (?:pattern) (?=pattern) (?!pattern)
- 论文阅读笔记:DeepRadiologyNet: Radiologist Level Pathology Detection in CT Head Images
- 正则表达式之 pattern+?、pattern*?、(?!pattern)、(?:pattern)
- Iterator Pattern & Composite Pattern
- Design pattern----Facade Pattern
- Design pattern----Strategy Pattern
- Design Pattern --------Observer pattern
- Design Pattern --- Factory Pattern
- 案例分析-引导设计
- poj3635 Full Tank? 最短路+dp
- JS
- python list set dic tuple总结及转换
- C++11新特性学习笔记
- Pattern Pathology
- 找工作的秘密
- 报表引擎API开发入门—带参程序数据集
- 云时代的分布式数据库:阿里分布式数据库服务DRDS
- App调试内存泄露之Context篇
- 谈一谈学习PS时的流程
- CSS代码段
- Don’t Stretch the Architecture Metaphors
- Ubuntu系统打开Vmware虚拟机出现could not open /dev/vmmon please make sure that the kernel moduel vmmon is load