What Nobody Told Me About Software Design

It was years ago when I was tasked to design a medium-sized system on my own. I was really excited as it was time to show the world how awesome a software designer I was.

Before that, I only saw systems that were designed by others and wondered why the heck did they miss so many things?

But as I started to design the system myself I realized how difficult it was to build even simple things. So many dependencies, so many limitations, and so much pressure!

I feel guilty about my own design although it is working fine. Because I know the loopholes in my system. I know how many good things I had to skip to finalize the design.

But recently I read a book by Steve McConnell where he expressed the truths about design and after reading that my mental peace was restored :P

So today I am sharing 5 truths about design that all of us need to keep in mind before designing anything again.

1. There is Nothing Clean about Software Design

Software design is a very sloppy and dirty process. The finished product is good and polished but the process is not nearly as tidy as the end result.

The product is clean but the process is dirty.

The design is sloppy because you have to hit many blind alleys. You have to make mistakes. You get things wrong. In fact, that’s the point of the design.

2. It’s All About Tradeoffs and Priorities

There is nothing called a perfect design. design is all about good for a particular cause.

An Ideal system would take zero space, have zero latency, Cost nothing to maintain, and support millions of customers at the same time.

But in reality, we have to make trade-offs. Sometimes as a designer, you have to choose a slightly poor architecture because you have time constraints.

Development time and feature support often can cause you to reconsider your design.

3. Design and Imagination Often Clashes

Design is about creating possibilities and sometimes restricting possibilities.

If we had an infinite amount of time we would build a system that would support every possible feature imaginable. But unfortunately, we are limited by time and resources.

As a designer, you should choose what you don’t want rather than what you want.

So, accept the fact that you can’t do everything and pick your sacrifices wisely.

4. Multiple Designs Can Be Correct at The Same Time

If you give 3 separate people to design the same feature each of them would come up with a completely 3 different design. But all of them can be correct at the same time.

There is no silver bullet in software design.

Sometimes as human beings we become arrogant with our own design and reject everything else that doesn’t match our idea of doing things.

So you have to be open about other people's ideas while working in a collaborative environment.

5. It’s a Rolling Ball

One tidy way of summarizing all of these is design is emerging. It’s a continuous process. It’s like a rolling ball that gathers good and bad things along the way.

We can’t get many things right until we start implementing the design in real life. Sometimes we have to change parts of the design. Sometimes we have to re-write it.

There is nothing wrong with an imperfect design.

You just have to accept the fact that what you designed can be absolutely rubbish and there is no shame in accepting a better one. It’s the one single truth about software design.


That is some of my thought about software design. Hope you will find it useful.

Happy Coding! :D

Get in touch with me via LinkedIn

Share this post

Read more articles...


First 5 Steps of Object-Oriented Design


How to Design a Clean Database


22 Best Practices for API Design

Profile Image

Who I am

Hi, I amMohammad Faisal, A full-stack software engineer @Cruise , working remotely from a small but beautiful country named Bangladesh.

I am most experienced inReactJS,NodeJS andAWS

Buy Me a Coffee Widget