Blog

Alexander Bird Software • Blog

Learning to build useful, valuable software as part of a team.
About

Getting Help as a Software Developer

Troubleshooting your code and what to do when you can't

I've put this list together for new developers, interns, or anyone transitioning from small, I-can-fit-all-the-code-in-my-head software projects to larger projects. In your transition, some of your questions and growing pains will be specific to the team and project you're working on, and other things will be common to any software endeavour. For most of the common things, there are freely available resources to bring you up to speed.

My suggestion is to focus your questions for your team on:

In other words: whatever you can learn online — those things that are relevant to any software project — look for online resources for. It's not because it's bad to ask your team for help with the standard things — it's just that you'll only have time for so many questions in a day, and why spend your questions on topics you can find easily on the internet? There are many other things that only your team mates can help you with.

I'm hoping these resources and strategies will help you to:

  1. feel ok with being stuck, then
  2. find answers on your own, or
  3. ask good questions of your colleagues (mentors/peers)

Feel OK with being stuck

Being stuck is a natural part of software development. You'll have to solve problems that nobody else has solved before (even if you're using tools that many people have used, and even if some part of the problem is very common). Get used to feeling totally stuck — no idea what to do next.

The thing is, often you are the person best qualified to solve the problem: you may not have the most experience or knowledge, but you know the context. While it can be tempting to ask someone more senior to bail you out, sooner or later in your career you'll be the most senior one around. Might as well start practising how to figure these things out now.

When you're feeling stuck:

  1. Set a time box: make note of the current time, and decide when you're going to give up and start asking someone else — make it 2 hours, 4 hours, 2 days — it depends on how big the problem is. Use your judgment.
  2. Go through your bag of tricks. For now, that might be suggestions in the sections below, or a set of things you're used to trying. You'll build up your own in time. Mine includes (in no particular order):
    • read documentation for a tool that I'm using that I'm not familiar with
    • can I add unit tests to understand what's going wrong?
    • can I debug the code and step through it to understand what's going wrong?
    • draw a picture of what I'm working on, see if it gives me any ideas
    • etc.
  3. When you reach the end of your time box or the end of your bag of tricks and are still stuck, prepare to ask for help: sort out in your mind (or on paper) what the problem is (I expect X but see Y), and what things (from your bag of tricks) you've tried. When you ask for help, you can then say something like:
    "Hey Alison, do you have a moment? I'm working on {context} but am seeing {Y} instead of {X} — I tried {A}, {B}, and {C} but none got me un-stuck. I tried googling for {search term} but that didn't help. Any suggestions?"
    Or, if you stopped because you reached the end of your time box,
    "Hey Ed, do you have a moment? I'm working on {context} but am seeing {Y} instead of {X} — I tried {A} and {B}, but it's been 4 hours and I figured I should get some help. Any suggestions?"
  4. Finally, after you've had their help, take a moment to reflect: "did they share some special knowledge with me, or could I have found that answer on my own? Why did they have the answer, but I didn't?" Try to learn something from their approach that will help you the next time you feel stuck. Sometimes, it's just a matter of them having more knowledge and experience than you — but other times it's because they know a trick for getting un-stuck that you could adopt.

Find answers on your own

Ask good questions of your colleagues


Something to add? Continue the conversation on Twitter


Written 2019-09