Content by Category
.NET 1.x
.NET 2.0
.NET 3.0
.NET 3.5
.NET 4.0
.NET 4.5
.NET Assemblies
.NET Framework
.NET Getting Started
Accessibility
ADO.NET
Advertorials
Agile Development
AJAX
Amazon Web Services
Analysis Services
Android
Architecture
Arduino
ASP .NET Web API
ASP.NET
ASP.NET MVC
ASP.NET WebForms
Azure
B2B (Business Integration)
BDD
Big Data
Bing
BizTalk
Book Excerpts
Build and Deploy
Business Intelligence
C#
C++
ClickOnce
Cloud Computing
Code Contracts
CODE Framework Info - non Technical
CODE on the Road!
COM+
Community
Conferences
Continuous Integration
Crystal Reports
CSLA.NET
CSS
Data
Debugger
Design Patterns
Development Process
Display Technologies
Distributed Computing
Document Database
DotNetNuke
DSL
Dynamic Languages
Dynamic Programming
Editorials
Enterprise Services ("COM+")
Entity Framework
Events
Expression Blend
F#
Fox to Fox
Frameworks
Functional Programming
Git
Graphics
HTML 5
Internet Explorer 8.0
Interviews
IOS
iPhone
Iron Ruby
Java
Java Script
JavaScript
jQuery
JSON
Lightswitch
LINQ
Linux
LUA
Mac OS X
MDX
Messaging
Metro
Microsoft Application Blocks
Microsoft Business Rules Framework
Microsoft Dynamics
Microsoft Expression
Microsoft Office
Mobile Development
Mobile PC
Mono
MsBuild
MVVM
MySQL
Network
NHibernate
node.js
NOSQL
Nuget
Object Oriented Development
Objective C
Odata
OLAP
Open Source
Opinion
Opinions
Oracle
ORM
Other Languages
Parallel Programming
Patterns
PHP
Podcasts
Post Mortem
PowerPoint
Print/Output
Prism
Product News
Product Reviews
Project Management
Prolog
Python
Q&A
Rails
Rake
Razor
Reporting Services
REST
RIA Services
Ruby
Ruby on Rails
Scheme
Search
Security
Services
SharePoint
SignalR
Silverlight
SOA
Social Networks
Software & Law
Software Business
Source Control
Speech-Enabled Applications
SQL Server
SQL Server 2000
SQL Server 2005
SQL Server 2008
SQL Server 2012
SQL Server CE/AnyWhere/Mobile/Compact
SSIS
Subversion
Sync Framework
Tablet PC
TDD
Team System
Techniques
Testing and Quality Control
TFS
Tips
TypeScript
UI Design
UML
User Groups
VB Script
VB.NET
Version Control
VFP and .NET
VFP and SQL Server
Virtual Earth
Vista
Visual Basic
Visual Basic 6 (and older)
Visual FoxPro
Visual Studio .NET
Visual Studio 11
Visual Studio 2005
Visual Studio 2008
Visual Studio 2010
Visual Studio 2011
Visual Studio 2012
Visual Studio Tools for Office
VSX
WCF
Web Development (general)
Web Services
WebMatrix
WF
Whitepapers
Windows 7
Windows 8
Windows Azure
Windows Live
Windows Phone 7
Windows Phone SDK
Windows Server
Windows Vista
WinForms
WinRT
Workflow
WPF
XAML
Xiine Documentation
XML
XNA
XSLT



LearnNow


XAMALOT
 


SSWUG

Reader rating:
Click here to read 2 comments about this article.
Article source: CoDe (2006 - Mar/Apr)

Bloated Designs, Over-Architecting, and Refactoring


Miguel Castro

Some time ago, I posted a blog entry entitled, “Refactor as you Develop.” I did so, because a buddy of mine out in Chicago was stuck in Refactor-hell, as he put it. Now, Eric (my buddy’s name) and I share a lot of design ideas and techniques so I know his comment [and term] came from the frustration he was feeling at that moment. However, it was not the first time I heard the term refactor used in a negative connotation so I thought it merited some comments.

It’s very rare that any project ends up exactly as the original design intended, at least from a code perspective. Nowadays, with buzz words swarming our industry like a locust plague, many forget the fundamentals of software development. The eagerness of many developers to have the “perfect” architecture laid out and the proper library of design patterns all set up in the class models has extended the “pre-code” period to an unnecessary length of time

But don’t misunderstand the above paragraph. Architecture and design are extremely important stages of any project. In fact, as a consultant I am sometimes called strictly for the initial architecting in order for another team to then take over the development. Such cases call for more detailed initial work to be done due to my absence afterward. But most projects I do tend to involve me from beginning to end, and indeed those are the ones I enjoy most. I have found that such projects require initial architecting and design but I also tend to push into the coding stage a little sooner rather than later.

Sure I design and lay out my initial object models, but even those typically start out as ORM models corresponding to some database layout. I don’t feel it necessary at this stage to figure out what pattern I need to used and where I will inject it. Nor do I find the need to plan out extreme code reuse from the very beginning. I am a big supporter of object-oriented programming and design-pattern use and the end result of my projects show that, but I don’t get this detailed in the very beginning. Such over-architecting delays the time you start putting code together, and chances are you’re going to wind up changing the design anyway. It can also bloat your design to a point of complexity that can further delay the start of the coding cycle. I’m not trying to lay out the model for agile development because, in fact, there are some points of Agile or Extreme programming that I am not a fan of (pair-programming comes to mind); nor am I saying that you don’t need to have any idea of what your app is going to need-that would be ridiculous on my part. I’m just raising the altitude from where I see a project at the beginning from 1,000 feet to 10,000 feet.

Your project may call for a lot of abstraction due to future enhancement requirements or need for a more open “plug-in” design. If you know this up-front, good; keep it as your goal throughout your development cycle, but don’t feel like you have to have your inheritance hierarchies down perfect and your strategy pattern all ready to go and put into play from the beginning. Get your functionality going using concreteness instead of abstraction. When you have a part of an application or a component working like you want, you can then go back and see what you can abstract or pull out into base classes for better reuse. In fact, a lot of this will almost snap out at you once you have a working piece of code.

I’m not recommending that you develop an entire application then go back and look at what you can change; that would be the other extreme. I’m talking about a constant looking-back at the code you’ve written at several “milestone” levels, usually points of functional achievement. There’s nothing wrong with writing a couple of classes in your model, then later noticing that they share a lot of code which you should not have to maintain twice. You can then refactor that code into a base class. You could repeat his simple refactor many times throughout the development of your project where your end result would be a nicely laid out object model with inheritance hierarchies that have grown throughout your development as the need has arisen. You can apply this simple example to Windows form visual-inheritance, as well as the application of any pattern.

Programming using concreteness initially, then refactoring to abstractions, can get you started faster, get you to your goal faster, and achieve all of this while maintaining my favorite pattern of all, consistent throughout the project-the K.I.S.S. pattern. (I’ll let you look that one up.)

Miguel A. Castro


How would you rate the quality of this article?
1 2 3 4 5
Poor      Outstanding

Tell us why you rated the content this way. (optional)

Average rating:
4.1 out of 5

18 people have rated this article.

Instantly Search Terabytes Of Text
“Lightning Fast”
– Redmond Mag
“Covers all data
sources” – eWeek
25+ fielded & full-text search options
dtSearch’s own document filters highlight hits in popular file types
Web Spider supports static & dynamic data
APIs for .NET, Java, C++, SQL, etc.
Win / Linux (64-bit & 32-bit)
www.dtSearch.com
 

      LearnNow

 

SSWUG