Top 10 pieces of advice for rookie software engineers

Steven Koh
Government Digital Services, Singapore
3 min readFeb 29, 2016

What you should know to ease your college hangover :)

  1. Work life does not start and end in semesters. The only way to complete your work early is to start early. Don’t procrastinate or wait for others to start first. Be kiasu. No one ever complains about starting a task too early or having too much time to do something.
  2. Work life does not start and end in semesters. Semester breaks no longer exist. But don’t let others squeeze you dry. Don’t burnout and drop out of the tech industry, like many others that I have seen. This is only the start of your marathon. Love your work and work darn hard at your sustainable pace — In the first three years of my work life, I worked/read till 12 am-1 am almost every day. That was sustainable until my baby girl came along :)
  3. Avoid binary thinking. Good software design is about making a series of good trade-offs. If it’s so clear-cut, our industry will not have so many programming languages, design patterns, architecture and opinionated people. The answer is often along the continuum and to make the right trade-off, you need to …
  4. Read voraciously. Start with these three books — Pragmatic Programmer, Code Complete 2 and The Art of Computer Programming — and you will be better than 60% of the developers in the market. Read these and be better than 80%. Every solid developer reads voraciously.
  5. Be prepared to spend lots of personal time learning. The acceptable pace of learning depends on industry trend, regardless of your convenience. Be on your toes and learn to learn. Find a good teacher, mentor and/or a coach. They have a multiplier effect on your learning. Work in a team. Attend meetups and share what you have learnt — you truly learn when you can teach. Graduation is the commencement of learning, no pun intended.
  6. Understand that opportunities do not come in a curriculum package with modules and known credits. They are like dots that you can’t connect looking forward. Introspect your intellectual humility and follow your heart because …
  7. Every opportunity has its fair share of fun moments, grunt work and challenges. Unless you believe in the cause, you will lack the mental perseverance to carry through the grunt work and overcome the challenges. Grit is the key to success.
  8. There’s no reality in reality and perception is everything. You might be darned good at X but if no one knows, it doesn't count. Volunteer for tech spikes, share your knowledge in tech retros, chapters and meetups, blog about the design and technical intricacies of your project. Show up and make your contribution felt. Therefore, learn to write well.
  9. Understand that organisations will maximise the total outcome by allocating resources based on meritocracy, not equality. Equal is not fair and fair is not equal, conflating the two will give you grief.
  10. Don’t despair when the going gets tough. Programming is a team sport. An effective team harnesses the individual’s strengths, not weaknesses. Learn to compensate your team’s weaknesses with your strengths and vice versa.
May the Force be with you :)

Updates

  • 2016 Mar — Here is a good article on the opportunity cost of missing out on chances to learn and grow by Edmund. Yes, it has a compounding effect so start early.
  • 2016 May — If you enjoyed this piece, you might like to read about our interview assessment. Btw, we are hiring! :)

--

--

Steven Koh
Government Digital Services, Singapore

GDS Director@GovTech | Pragmatic optimist | Build high-performing teams, delightful products, and fun-loving communities | #techforpublicgood