Patience in Software Engineering

December 10, 2024

tom pottiger hCQGqbZmsAk unsplash

Photo by Tom Pottiger on Unsplash

Hosting bonfire nights at my home is one of my favorite things.

I set up a small fire pit (so not really a bonfire after all…) when we first moved in many years ago and have since hosted probably close to two to three dozen of these nights. I’ll crank up the fire, set up the chairs, and people trickle in and out one by one. In summer, we’ll have cold drinks in a cooler and warm cocoa or cider in the winter.

Hosting these events (along with my love for camping) has helped me get good at building fires. I might not be ready to tackle Alone, but I’m a pretty decent fire builder.

And one key to building a great fire is patience.

You can’t build a fire by holding a small lighter or match to a huge log and expect it to be roaring a few minutes later. You also can’t rush an already burning fire and dump everything all at once, or you’ll smother it.

No, to build a good fire, you need to practice patience. You prepare your kindling and set up your wood before ever lighting a match or making a spark. Once it starts, you watch where the hotspots are (or aren’t) and adjust accordingly as you add new logs to keep it burning. You’ll build a fire faster by being methodical and patient rather than hopelessly trying to light a log with flint and steel.

Sadly, the software industry has forgotten patience. We want to ship things too quickly, make large assumptions about our users and force paradigms that are poor at best and broken at worst. We are trying to light a log with a small lighter.

We need to embrace one particular definition of being patient that I like, and it’s this:

not being hasty or impetuous

A codebase full of hasty decisions is a lousy codebase indeed.

Here are some ways in which software engineers can practice patience in their craft (beyond being patient with one another, which is valuable in its own right).

Code Reviews

Many engineers see code reviews as a hassle and, therefore, do anything they can to get them off their plate. While I don’t have anything against engineers working to reduce the lead or cycle time of a code review, when the reviewer is unwilling to spend an appropriate amount of time reviewing, the entire process suffers. Code will rot over time, incorrect suggestions or claims will be made, and the opportunity for learning is diminished.

Speaking from personal experience, anytime I’ve left comments on a pull request that were made hastily (without double-checking a function or looking up evidence), I’ve made incorrect suggestions and had to eat my words later. Having the patience and discipline to double-check documentation or re-read always has a net positive effect.

It’s true for the other side as well. When authors are too quick to ignore or scoff at a suggestion made by a team member, trust is broken, bitterness and brew, and the code is likely to decay. I’m not saying an author needs to accept every suggestion or even comment back on every item, but an author should respond to the majority of comments and give reasons why they are choosing to accept it or not.

One last tip before moving on: avoid the common “I’ll do it in another pull request” excuse. If someone leaves good feedback on your code and it’s reasonable to implement, why not do it now? I’ve seen far too many bugs make it to production because an engineer convinced another they would do something later, and because of fear of conflict, it got approved. But of course, the work never got done later, and a bug slipped by. Take the time to do the thing you will do later now.

Software Design

Ever had a “simple feature” to add to a system to find it surprisingly complicated to accomplish(like in this hilarious sketch)? It was likely caused by either a lack of domain knowledge or a lack of patience in learning that domain before shipping (and likely a little bit of both). We create abstractions that don’t match the real world, tightly couple concepts that should be separated, and or create abstraction inversions that leave you wondering “why?“.

Rushed or hasty software design often has terrible long-term consequences.

The sad bit is that we think our insistence for getting these abstractions or ideas in as soon as possible will save time in the end. “We won’t have time to get it right later on.” The irony is they are right: we won’t get dedicated time to fix hasty decisions until the entire system is falling apart. They fulfilled their own prophecy.

And look: I get the goal. Finding leverage through reusable components and shared tooling will help your teams ship faster.

The issue isn’t the end goal but the path taken to get there. Instead of hasty abstractions or settling at the first concept that “works”, practice patience and let the code teach you. Start with simple concepts and flexible components that allow the right components to emerge over time. You’ll end up with a much better codebase taking this path than if you had accepted the first attempt at an idea or scrambled to “make it right.”

A good way to think about this that has helped me is to think about how complexity happens. Complexity is tough to remove but really easy to add. By deferring complexity as much as you reasonably can, you save yourself (and your team!) the trouble of having to remove it later.

To be fair, you’ll never get it all right and still build too much complexity too soon. But it’s better to have a few missteps than constantly having to fight your codebase.


These are just two areas in which I’ve seen patience over time speed up the development process rather than slow it down. Being willing to slow down, thinking critically and carefully, and waiting before pushing an idea can help your code grow naturally vs. having to untangle a mess each time you need to implement something.

As the saying goes, “Slow is smooth; smooth is fast.”

Happy coding!

👋🏼 p.s. If you liked this post, you'll love my book, Code Review Champion! In it, I share everything I've learned from over a decade in the industry about building a code review practice to set you and your team apart!


If you enjoyed this article, you should join my newsletter! Every other Tuesday, I send you tools, resources, and a new article to help you build great teams that build great software.


Dan Goslen is a software engineer, climber, and coffee drinker. He has spent 10 years writing software systems that range from monoliths to micro-services and everywhere in between. He's passionate about building great software teams that build great software. He currently works as a software engineer in Raleigh, NC where he lives with his wife and son.