Andrew Pollack's Blog

Technology, Family, Entertainment, Politics, and Random Noise

Time to repeat some of the best advice on programming I've ever read.

By Andrew Pollack on 06/06/2006 at 10:03 PM EDT

A couple of years ago I read something Richard Schwartz wrote about "Second System Syndrome". I can't seem to find the original now, but here's a link to the topic on wikipedia. Since reading it, an understanding of this topic has been directly responsible for saving my backside about a dozen times.

The general idea, is that you build something that by chance, luck, and a little skill turns out really useful. As a reward, you get the chance to do it again. You resolve that this time you're really going to do it right. What you end up with, if you're not careful, is something so grossly overengineered and poorly suited to the actual problem that you design the very utility and flexibility right out.

Think of all the "Second System" projects you can recall that never even get finished. The thing to remember when you go to do your rebuild, is that you're not solving the same problem again. You're solving a similar problem in an entirely new context. Go back to the basics that made the original successful. You need start with the reason you're building it. From the design goals, plan your solution. Borrow from the original but don't copy it. Trust that you've learned something along the way and those original ideas will end up rolled into the new solution along with the fresh thinking and economy of design that made your first work succeed.

I plan to revisit this topic from time to time, because it has become so key to how I work.

Today I moved into test with one of the largest "second system" rebuilds I've ever done. It has nothing to do with Second Signal, but rather is traditional Notes work related to design I've worked on for years and years. As I said, its in "alpha" test on my own servers tonight, and by Friday I will have it in the hands of my client. The work represents something like two months of revenue, and if I hadn't really pounded my head and forced myself to avoid making those "second system" mistakes I'd really be underwater right now.

There are  - loading -  comments....

Other Recent Stories...

  1. 05/05/2016Is the growing social-sourced economy the modern back door into socialism?Is the growing social-sourced economy the modern back door into socialism? I read a really insightful post a couple of days ago that suggested the use of social network funding sites like “Go Fund Me” and “Kickstarter” have come about and gained popularity in part because the existing economy in no longer serving its purpose for anyone who isn’t already wealthy. Have the traditional ways to get new ventures funded become closed to all but a few who aren’t already connected to them and so onerous as to make ...... 
  2. 04/20/2016Want to be whitelisted? Here are some sensible rules for web site advertisingAn increasing number of websites are now detecting when users have ad-blocking enabled, and refuse to show content unless you "whitelist" their site (disable your ad-blocking for them). I think that is a fair decision on their part, it's how they pay for the site. However, if you want me (and many others) to white list your site, there are some rules you should follow. If you violate these rules, I won't whitelist your site, I'll just find content elsewhere. 1. The total space taken up by advertisements ...... 
  3. 12/30/2015Fantastic new series on Syfy called “The Expanse” – for people who love traditional science fiction[] “The Expanse” is a new science fiction series being broadcast onthe Syfy channelthis winter. It’s closely based on a series of books by author James S. A. Corey beginning with “Leviathan Wakes”. There are 5 books in the “Expanse” series so far. If you’re a fan of the novels you’ll appreciate how closely the books are followed.TIP: The first five episodes are already available on If you’re having trouble getting into the characters and plot, use those to get up to speed.The worlds created for ...... 
  4. 10/20/2015My suggestion is to stay away from PayAnywhere(dot)com  
  5. 08/07/2015Here is one for you VMWARE gurus - particularly if you run ESXi without fancy drive arrays 
  6. 08/06/2015The Killer of Orphans (Orphan Documents) 
  7. 06/02/2015Homeopathic Marketing: Traveler on my Android is now calling itself VERSE. Allow me to translate that for the IBM Notes community... 
  8. 03/17/2015A review of British Airways Premium Economy Service – How to destroy customer goodwill all at once 
  9. 02/26/2015There's a bug in how @TextToTime() and @ToTime() process date strings related to international standards and browser settings. 
  10. 01/21/2015Delivering two new presentations at Developer Camp (EntwicklerCamp) 2015 in Germany 
Click here for more articles.....

pen icon Comment Entry
Your Name
*Your Email
* Your email address is required, but not displayed.
Your thoughts....
Remember Me  

Please wait while your document is saved.