Monday, December 31, 2012

13 Habits to Becoming an Excellent Software Developer in 2013

We are what we repeatedly do. Excellence, then, is not an act, but a habit. Aristotle

Excellence is a habit something that we repeatedly do. You can make excellence part of your daily routine as well, particularly if you develop and maintain software for a living.

I'm continually surprised by how many "experienced" developers are actually not excellent developers. However, it does not have to be that way. By paying attention to a few small details, consistently and repeatedly, even the most inexperienced developer can execute and deliver flawlessly.

With the upcoming New Year, I've put together my thoughts on thirteen (13) practices that can quickly turn anyone into a great developer. These practices apply to most development environments, languages and configurations. I make few assumptions about the tools you are using to develop software. I do assume the following:

  • You are using source control.
  • You have a fully-functioning local environment.
  • You have a production-like test environment.

Test everything

I should probably rename this to "run everything". I mean running your code, and looking at your application to make sure there are no obvious errors. Your program compiles cleanly. There are no spelling mistakes, no typos, nothing obvious. Run through the primary path, that most of your users will encounter, as well as any alternate paths, error paths and the the like. Try to run through all branches in your code to make sure they work.

In addition to your application code and visible screens, also run any scripts, jobs and utility tasks that are part of your system. If you're scheduling an offline task, run it manually to make sure it works before scheduling it.

Even if you're using automated tests, take a look at your application as a user would, and make sure that there are no obvious errors.

Look at your outputs

When your running any part of your application, there is a lot of output generated that can provide you with valuable information about how your application is running.

When running your application, follow the logs and look at what is happening. Are the outputs the ones you expect? Is there anything extra there? Is anything missing?

When running any scripts, is the output what you expect? Did the script error out or end cleanly? Did the script produce the results and changes you were expecting?

If you have automated tests, did they finish cleanly? Did every test run as expected? Did the tests run fast enough?

Review diffs before committing

Look over each file that's changed and each line that's changed before making a commit, even if it's a local commit. Know exactly what changes you are making to the code base at any point. Too many times, I've run into the case where files were "accidentally" committed to the code base. These types of unexpected changes can be stopped with this one simple practice.

If you're working in very small increments on thin slices of functionality, the number of changes will be small and the review will be quick.

Review the functionality with someone

When you're done working on your feature, change or fix, bring someone over and show them what you've done. Talk them through what the system does, and show them how the different scenarios work. Even better, let them use the system and point out any issues or errors.

Don't get frustrated when the reviewers start asking for changes. No matter how well your team defined the feature, they don't have perfect vision into the future. By seeing the feature in action, your team now has more information about how to make it work even better. Change is an integral part of software development. Latch on to it and run with it, as a way to create some truly amazing products.

Review the implementation with someone

After you've got the feature working, and your implementation is complete, review what you've done with other developers. This could be done real-time while pairing, or after the fact with a code review or a pull-request.

Be open minded about what others have to say. Leverage any feedback as collective experience to produce the best code possible. Use this as a chance to learn new techniques, and to hear about new libraries. Remember that they're commenting on your code and the implementation, and not on you as a developer.

Work in small increments, stay stable and commit often

It is much easier to work on a small function or a small screen, than a complex business process or a series of screens. Break your functionality down into small functions, and build them out incrementally. Evolve your system to the desired fully functional system that everyone dreams of.

In addition to focus, you'll also get the motivation that comes from a rapid succession of wins as each function is created. You'll also be able to get to stability quickly, and change direction quickly.

When a teammate wants to see what you're working on, you should never be more than a few minutes from showing them. Your code changes should be small enough to thrown away and recreate as needed.

Once your small changes work, commit them to your repository. This allows you to experiment, while having a safe place to come back to. This also allows you to change gears as needed. By being incremental and focused, your system is always in some working state that can evolve towards full functionality.

Keep separate features on separate branches

For each feature or function that you are building, create a separate branch in your code repository. Don't mix features together. Let your features evolve independently. You never know what kind of feedback you may get, and which features will need more or less work after others have seen them.

Give each feature the option to be deployed independently, by allowing each branch to be deployed independently. Once you have two features on a single branch, you've coupled them.

Write (well) to your future self

Pay attention to the words you choose, whether it's variables, methods, classes, modules, comments or commit messages. In the moment when you're developing a feature, everything seems obvious, like you'll remember everything. But remember two things: your teammates don't have the immediate context that you do now, and you will not have that immediate context some short time into the future.

Editors look for ambiguous pronouns when they review writing, to make sure that everything is clear to the reader. Take that same level of care, and make everything as clear as you can.

Test everything again

Your engagement with a feature and the related code only starts when you commit to the repository. From there, follow your code through to a test environment, ideally an environment that is similar to production. Review your feature, show it off, get feedback, check that it works and that it performs.

Don't stop there, though. Once you're feature is deployed, do the same in your production environment. At that point, take a deep breath, smile, and really call your feature DONE.

Defend everything you do

Justify everything. Every line of code you write. Every line you don't write. Everything you add, and everything you delete. Every name you choose, and every name you avoid. Everything you decide to work on first, and everything you decide to put off for later. Every choice you make, and every option you weigh.

The answer can be as simple as "I saw an example on stackoverflow", or as nuanced as "I applied XXX pattern and referenced in YYY book, trading off ZZZ for WWW". Reply at your appropriate level, but know why you've done what you've done.

You're answer doesn't need to be right, but it does need to reflect the best you knew at the time.

Write things down

Development work gets complex pretty quickly. Don't add to the complexity by forgetting what you need to do. Whether you're discussing a new feature, or having a code review, or discussing what needs to be done that day.

Keep your list nearby. Even better, keep it public. Let everyone see what you're working on. You and a teammate might recognize some duplicate effort, or a way to streamline some of the work.

Communicate with your team

Become a radiator of information. What are you working on? What problems are you having? What solutions have you found? What could be done better? When are you integrating and deploying your changes?

Don't limit this to technical tasks, either. When are you taking time off? Are you coming in late tomorrow? Are you leaving early on Friday? Let your teammates know, early and often.

Don't be afraid of information overload, at least not in this case. The more information everyone has, the better the whole team can act and react.

You are not alone

Ask for help. That's what your pair, your team, your company and your community are for.

Happy New Year! Have a great 2013! Become an excellent developer!


  1. What, no pair programming?

    Happy New Year - good to see you blogging again.

    1. Happy New Year to you, too, Tom!

      I think pair programming is a great way to get high-quality software done quickly. Pairing also comes with built-in opportunities for learning, and I've found it to be lots of fun.

      With this list, I was focusing on tactics that an individual can learn and practice, towards become an excellent software developer and a great contributor to the team.

  2. This comment has been removed by the author.

  3. Really awesome blog. Your blog is really useful for me. Thanks for sharing this informative blog. Keep update your blog. Recently I did Software Testing Course in Chennai at a reputed training institutes. This is really useful for me to make a bright future in IT field.

  4. The future of software testing is on positive note. It offers huge career prospects for talented professionals to be skilled software testers. Best software testing training institute in Chennai | Software Testing Training in Chennai | Software testing training institute Chennai

  5. Thanks for all this tips! I will show it to our software development company, because it seems they forgot some of these rules. It's good firm but sometimes i think that we could make some parts of project by ourselves.

  6. Thanks for the information. Helped us to convince most on how this process works and what they could achieve by following these guidelines design services

  7. This is the best application on the drop today. There access to enjoy great moments of relaxation: age of war 2|
    age of war 5
    Great! Thanks for sharing the information.Summon creatures to fight enemy units and demolish the opposing castle. Your castle is equipped with a crossbow, which you can use to shoot enemies age of war 6. Make sure you upgrade skills to increase your chances of winning battles.
    The goal of Age of War is to survive longer than the computer and to outlast him you’ll need to train the right troops while balancing your offence and defence in this high paced, quick thinking flash game age of war 4
    . Train troops of you own to combat the computers. As you kill off the computer troops, you will gain EXP and you will eventually advance to the next age.
    Choose a starter deck and prepare for an epic war!age of war 3

    Command your units in each battle to attack the enemy’s castle, while protecting your own base earn to die 2. Earn and upgrade cards to help you conquer the land.age of war

    happy wheels | tank trouble
    Thanks for the best was very useful for me.keep sharing such ideas in the future as well.this was actually what i was looking for,and i am glad to came here!
    cubefield It contains a plethora of tools and objects for level building such as harpoon guns,blocks and vans. Users can upload their maps to a public server where they are accessible

  8. Really cool post, highly informative and professionally written and I am glad to be a visitor of this perfect blog, thank you for this rare info! , Regards, servicenow training in hyderabad

  9. ATX tax service provider keeps data securely on cloud servers which are safely stored in their high-class SSAE No.16 compliant data centers. To keep data secure hosting service provider uses high quality anti - spyware software, latest firewall systems, high quality anti - virus software, high class intrusion prevention system(IPS), round the clock network monitoring, and many other stern security measures. driver toolkit key

  10. Thanks for all this tips! I will show it to our software development company, because it seems they forgot some of these rules. It's good firm but sometimes i think that we could make some parts of project by ourselves.

  11. Hi,

    It was excellent information, thanks for sharing and please keep sharing such more articles.
    Selenium training in Chennai | Best Selenium training institute in Chennai

  12. It is amazing and wonderful to visit your site.Thanks for sharing this information,this is useful to me...
    Android Training in Chennai
    Ios Training in Chennai

  13. Thank you for the advice, take a note, our company also uses outsourcing

  14. The companies can work out on some other primary areas of development after selecting the affordable PHP developer.

  15. Needed to compose you a very little word to thank you yet again regarding the nice suggestions you’ve contributed here.

  16. My developer is trying to convince me to move to .net from PHP. I have always disliked the idea because of the expenses. But he’s trying none the less. I’ve been using Movable-type on several websites for about a year and am anxious about switching to another platform. I have heard great things about Is there a way I can transfer all my WordPress posts into it? Any help would be appreciated.

    DevOps Training in Chennai

  17. Superb. I really enjoyed very much with this article here. Really it is an amazing article I had ever read. I hope it will help a lot for all. Thank you so much for this amazing posts and please keep update like this excellent article. thank you for sharing such a great blog with us.

    python training in chennai | python training in bangalore

    python online training | python training in pune

    python training in chennai

  18. This is quite educational arrange. It has famous breeding about what I rarity to vouch. Colossal proverb. This trumpet is a famous tone to nab to troths. Congratulations on a career well achieved. This arrange is synchronous s informative impolite festivity to pity. I appreciated what you ok extremely here.
    java training in chennai | java training in bangalore

    java online training | java training in pune

  19. Wow it is really wonderful and awesome thus it is very much useful for me to understand many concepts and helped me a lot. it is really explainable very well and i got more information from your blog.

    rpa training in Chennai | rpa training in pune

    rpa training in tambaram | rpa training in sholinganallur

    rpa training in Chennai | rpa training in velachery

    rpa online training | rpa training in bangalore

  20. Greetings. I know this is somewhat off-topic, but I was wondering if you knew where I could get a captcha plugin for my comment form? I’m using the same blog platform like yours, and I’m having difficulty finding one? Thanks a lot.

    AWS Training in Bangalore | Amazon Web Services Training in Bangalore

    Amazon Web Services Training in Pune | Best AWS Training in Pune

    AWS Online Training | Online AWS Certification Course - Gangboard

  21. I recently came across your blog and have been reading along. I thought I would leave my first comment.
    python online training
    python training in OMR
    python training course in chennai

  22. Nice post. By reading your blog, i get inspired and this provides some useful information. Thank you for posting this exclusive post for our vision. 
    Devops Training in pune


  23. Hmm, it seems like your site ate my first comment (it was extremely long) so I guess I’ll just sum it up what I had written and say, I’m thoroughly enjoying your blog. I as well as an aspiring blog writer, but I’m still new to the whole thing. Do you have any recommendations for newbie blog writers? I’d appreciate it.

    AWS Interview Questions And Answers

    AWS Training in Bangalore | Amazon Web Services Training in Bangalore

    AWS Training in Pune | Best Amazon Web Services Training in Pune

    Amazon Web Services Training in Pune | Best AWS Training in Pune

    AWS Online Training | Online AWS Certification Course - Gangboard

  24. I’m bookmarking and will be tweeting this to my followers! Wonderful blog and amazing design and style.
    nebosh course in chennai

  25. Softhax
    Find best android iOS apps free now. Install them on your phone with easily simple steps. Free android games, free applications. IDM BUILD 10 Cracked Latest Version

  26. The project manager works in conjunction with a client-facing senior engineer called a software business analyst.

  27. We have the coolest games in online casinos. very best gambling at online casinos Casinos are like in Las Vegas, come in and row your money in bags.

  28. I would like to thank you for your nicely written post, its informative and your writing style encouraged me to read it till end. Thanks
    devops online training

    aws online training

    data science with python online training

    data science online training

    rpa online training

  29. You’ve written a really great article here. Your writing style makes this material easy to understand.. I agree with some of the many points you have made. Thank you for this is real thought-provoking content

    Microsoft Azure online training
    Selenium online training
    Java online training
    Python online training
    uipath online training

  30. Thanks for the excellent article. Very Informative blog.

    Article submission sites

  31. Its as if you had a great grasp on the subject matter, but you forgot to include your readers. Perhaps you should think about this from more than one angle.
    date analytics certification training courses
    data science courses training
    data analytics certification courses in Bangalore
    ExcelR Data science courses in Bangalore

  32. Nice tips for Software Developers, Very informative post, thanks for sharing.

    ExcelR Data Science in Bangalore

  33. Attend The Python training in bangalore From ExcelR. Practical Python training in bangalore Sessions With Assured Placement Support From Experienced Faculty. ExcelR Offers The Python training in bangalore.
    python training in bangalore

  34. wow, great, I was wondering how to cure acne naturally. and found your site by google, learned a lot, now i’m a bit clear. I’ve bookmark your site and also add rss. keep us updated.


  35. I was just browsing through the internet looking for some information and came across your blog. I am impressed by the information that you have on this blog. It shows how well you understand this subject. Bookmarked this page, will come back for science course in dubai

  36. I really enjoy simply reading all of your weblogs. Simply wanted to inform you that you have people like me who appreciate your work. Definitely a great post. Hats off to you! The information that you have provided is very science course in dubai

  37. Amazing knowledge and I like to share this kind of information with my friends and hope they like it they why I do
    Data Science Course in Pune

  38. Nice information, valuable and excellent design, as share good stuff with good ideas and concepts, lots of great information and inspiration, both of which I need, thanks to offer such a helpful information science course in dubai

  39. thanks for sharing informative article, best article of this week.
    learn about iphone X
    top 7 best washing machine
    iphone XR vs XS max
    Samsung a90

  40. I like viewing web sites which comprehend the price of delivering the excellent useful resource Python training in pune free of charge. I truly adored reading your posting. Thank you!


  41. This is a wonderful article, Given so much info in it, These type of articles keeps the users interest in the website, and keep on sharing more ... good luck.
    How to Start A blog 2019
    Eid AL ADHA

  42. Its as if you had a great grasp on the subject matter, but you forgot to include your readers. Perhaps you should think about this from more than one angle.
    Data Science Courses