My Lessons in Software Engineering

My Lessons in Software Engineering

I have compiled this list in an effort to organise my knowledge, my lessons and experiences, and also provide a preliminary list of topics I will write about.

I hope the list will also be valuable by itself, maybe as a guide for others wanting to embark on the same journey.

Enjoy!

Engineering

  1. Simplify things down to first principles.
  2. Do coding challenges.
  3. Learn about algorithms and data structures.
  4. Understand the throughput of your system.
  5. Have a hobby project.
  6. Done means released.
  7. Keep everything in version control.
  8. Every software developer is a software tester.
  9. Create unit tests for majority of your code.
  10. Use the DORA metrics.
  11. Continuous delivery is the only way to produce quality software.
  12. If you’re unsure iterate quicker.
  13. Learn DevOps techniques and motivation.
  14. Trust the operating system with the basics.
  15. Use actor model when in need of asynchrony.
  16. Use test driven development.
  17. Do not get distracted by hype, focus on the basics and principles.
  18. Test driven development and REPL driven development are flavours of the same thing.
  19. Embrace REPL driven development.
  20. Learn Linux.
  21. Use GIT.
  22. Learn what types of databases there are.
  23. Learn the value proposition of cloud services.
  24. Use configuration management and deploy with containers.
  25. Automate everything.
  26. Comments are a code smell.
  27. Learn and understand the motivation for the actor model. Reading more about Erlang is a huge help.
  28. Understand map, reduce, zip and filter.
  29. Implement vertical automation from scratch at least once.
  30. Learn functional programming, with a special focus on data flow and pure functions.
  31. Learn 7 languages. Then choose 2. My choices are Clojure and Python.
  32. Learn and use sequence diagrams, entity diagrams and dependency diagrams.
  33. Avoid by-reference object oriented idioms.

Professionalism

  1. Organise your work around the value stream and strive to remove constraints on throughput.
  2. Managing a project only works if you organise around the value stream. Implement communication channels that increase efficiency of creating and delivering the value stream.
  3. Constraints and simplicity inspire creativity.
  4. Limit work in progress. Time spent waiting is the biggest killer of productive work, with the second being redoing the same things multiple times.
  5. Increase readability, and always leave the code / project in better state.
  6. 20% of features bring 80% of value. Do you need the rest?
  7. Follow a process until it stops making sense i.e. moving you forward, towards the goal.
  8. Study the old masters, learn from their mistakes, and understand the limitations they were working with.
  9. Work in small steps and iterate. Embrace the true meaning of agility.
  10. Work smart, not hard.
  11. Focus on the goal of each sprint, each feature, and each project.
  12. Communicate your expectations clearly.
  13. Keep your designs simple.
  14. Do not accept artificial complexity.
  15. Understand lean principles and practices.
  16. Minimise documentation and focus on purpose of your solution.
  17. Learn by teaching.
  18. Use fear as a motivator to improve.
  19. Understand Pareto principle.
  20. Evaluate importance and urgency separately. Learn about Eisenhower matrix.
  21. Never develop software you don’t understand.
  22. Create simplifications and tools for yourself. They will frequently be a great help for others.
  23. Learn to let go - don’t get married to your ideas and designs.
  24. Understand the value stream.
  25. Do not overcomplicate or overdeliver. Gold plating is rarely the goal, and frequently attempt at gold plating turns into rot plating.
  26. Always integrate early and vertically. Every time you do not integrate vertically, you introduce risk in your design.
  27. Learn the meaning of YAGNI, DRY, and KISS.
  28. Do not lose focus of the purpose of the software. It is supposed to be soft.
  29. Get over public speaking.
  30. Readability is more important than correctness or optimisation.
  31. You never deliver anything meaningful alone.
  32. Develop anything you are unsure about in pairs, especially at the start of your journey.
  33. Say no to word salads!

Philosophy

  1. Figure out your mission in life and follow it. Don’t let yourself get distracted for too long.
  2. Be the change you want to see in others.
  3. Assume noble intent.
  4. Study philosophy.
  5. Embrace empiricism and scientific method.
  6. If your tests fail, your idea is wrong. That's it.
  7. Not all pain is bad.
  8. If you’re stuck on a problem, sleep on it.
  9. Maintain work life balance and a healthy lifestyle.
  10. Read regularly and develop yourself on the weekend.
  11. Cut out waste wherever you see it.
  12. Don’t wait to be told what to do.
  13. If doing the right thing is difficult, that just means it's even more important to do the right thing.
  14. Knowing when to stop is important. Flow is not tunnel-vision, and tunnel-vision is not flow.
  15. Knowing what not to do is more important than knowing what to do.
  16. Think outside the box. Do not let existing processes, practices, culture limit your imagination.
  17. Bring the pain forward.
  18. Don’t try to prove yourself correct. Try to prove yourself wrong.
  19. Do not expect the journey will be easy.
  20. Use criticism as an improvement input. Handle toxic people and their criticism separately.
  21. Never lose patience with those you are helping.
  22. Be responsible.
  23. Improve continuously.
  24. Strive to have as many true beliefs and as few false beliefs as possible.
  25. Ask others to criticise and judge your work.
  26. Don’t be too hard on yourself.
  27. Get a creative hobby, which is completely disconnected from your work e.g. painting, music, sport etc.
  28. As software engineer you spend 80% of your time programming not machines, but people.
  29. In digital age less is more, and simplicity and focus on value are the difference between success and failure.
  30. If it's not released into production, it is waste. Some waste is required, most is not.

If you enjoyed the list please stick around, read my other articles, leave a comment, share and like. Also remember to come back in some time. The items on the list will become links to my articles.

Live long and prosper, Piotr Kruczkowski

Many good points my friend. It's strange, I never had the feeling we were so aligned while working for the same company. Possibly our journey outside NI taught us some important lessons.

要查看或添加评论,请登录

Piotr Kruczkowski的更多文章

社区洞察

其他会员也浏览了