here are my top tips on technical writing after 8 years and 700 posts

Yan Cui

I help clients go faster for less using serverless technologies.

Since Dec 26th 2009, I have written regularly on this blog on a variety of technical topics. Suffice to say that I have had a lot of practice of technical writing!

I love learning, and I love sharing. What I learn I like to share through writing, as it also helps me solidify my understanding too.

Over the last 3 months, my posts have received around 75K views per month across medium and this blog. So the evidence suggests that my writings aren’t turning readers away at least!

So to help more people share their knowledge and insights, here are a few simple rules that I follow when I write.

Mind the “curse of expertise”

The most important rule of thumb is to always remember you are the expert of your domain. When you share knowledge & experience, you need to be mindful what assumptions you’re making of the reader.

Especially when you discuss the merits or problems of an approach. Always state your assumption and context explicitly up front. This helps the reader understand WHY you’re doing this, and the constraints you’re working with.

In the immortal words of Simon Sinek, start with why, which brings us to the next point.

Sell the problem, NOT the solution

“Brad, sell me this pen”
Like that great scene in “the wolf of wall street” where Di Caprio asked Jon Bernthal to sell him a pen.

Create the demand, then supply the solution.

Sell the problem to the reader. Help them understand why it’s a problem worth solving. The merits of your solution are irrelevant without an interesting and worthwhile problem.

Where possible I try to set out what a “good” solution would look like, and what properties it should have. After describing the solution I would then finish off with the tradeoffs I have to make. This would usually evolve around the pillars of cost, complexity and efficiency.

If you don’t define what “good” is up front, then it’s easy for cognitive biases to creep in. We often subconsciously bend the definition of “good” to fit our solution, and lose objectivity in the process. We all have this confirmation bias, there’s no escaping it. But defining “good” ahead of time helps keep us honest with ourselves.

Keep in mind that your solution might only work in specific contexts. If people adopt your solution without understanding the context in which it worked, then they risk failure. Worse yet, if the failures are not obvious enough, then you might have started another cargo cult

Keep it short

On medium, you can see how long your post takes to read and how many people read it start to end. Unsurprisingly there is a clear trend that longer posts have a lower read %.

I compiled the stats for my posts related to serverless and this is what I see.

This is reflected in my personal reading habits too. I tend to finish longer posts over several sitting as I often lose my attention span midway. I’m seldom able to finish a long post in one sitting, even if I ‘m really engaged by it.

What that means to you is that you should keep things short, punchy, and to the point. Don’t linger with your words and try to explain things to the Nth degree.

If need be, use bullet points, and keep each to one line.

Write the post, then read it back a few times. With each run, cut out unnecessary words or rephrase sentences to make them more concise.

For example, “to be or not to be, that is the question” might be vague and leaves a lot to the reader. The longer, more expansive version is actually far less clear!

Courtesy of Kevlin Henney’s talk “7 ineffective coding habits of many programmer” – https://www.slideshare.net/Kevlin/seven-ineffective-coding-habits-of-many-programmers

Be honest

Goes without saying :-P

Picture says a thousand words

Apply common sense, too many pictures is also not good.

Also, keep pictures relevant. We all love cat pictures, but too much of it (or used out-of-context) is off putting.

Start strong

I follow this advice when giving talks as well, and try to kick off a presentation or post with a strong message.

Think of your reader’s attention span as a currency. You have to earn the audience’s attention before you can spend them on technical discussions.

Conclusions

So that’s it, 6 simple rules that I follow whenever I write. The freecodecamp folks also have some very good advice for writing on medium.

I hope this post helps you improve your writing. If you have any suggestions on how I can improve my own writing style, please feel free to let me know via the comments below.

Happy Easter everyone!

Whenever you’re ready, here are 4 ways I can help you:

  1. Production-Ready Serverless: Join 20+ AWS Heroes & Community Builders and 1000+ other students in levelling up your serverless game. This is your one-stop shop for quickly levelling up your serverless skills.
  2. Do you want to know how to test serverless architectures with a fast dev & test loop? Check out my latest course, Testing Serverless Architectures and learn the smart way to test serverless.
  3. I help clients launch product ideas, improve their development processes and upskill their teams. If you’d like to work together, then let’s get in touch.
  4. Join my community on Discord, ask questions, and join the discussion on all things AWS and Serverless.