The Soft Side of Software

  Download PDF version of this article PDF

10 Ways to Be a Better Interviewer

Plan ahead to make the interview a successful one.


Kate Matsudaira

In many ways interviewing is an art. You have one hour (more if you count the cumulative interview time) to determine if the candidate has the desired skills, and, more importantly, if you would enjoy working with this person. That is a lot of ground to cover!

And as if finding out all that information isn't a daunting enough task, you also need to make sure that the candidate has a really great experience while visiting your company (after all, people talk and you want them to be saying good things—since this candidate may not be your next hire, but someone he or she meets may be...).

As an interviewer, the key to your success is preparation. Planning will help ensure the success of the interview (both in terms of getting the information you need and giving the candidate a good impression).

The following list is advice to consider prior to stepping into that room with two chairs and a whiteboard.

1. Review the candidate's resume

Read every line of every resume (and this goes for the really long ones that go on for four pages). Where have these candidates worked? How long did they stay in a role and did their positions change? These questions make for interesting conversation topics. Hopefully there will be something in a candidate's background that piques your interest and can be great fodder for starting the interview with some common ground. This can put candidates at ease, giving them their greatest chance of success.

2. Review feedback from previous interviews

Most software companies have a longer interview process that can start with phone-screen or homework problems and evolve from there. If the candidate has done homework problems, or your teammates have taken the time to type up feedback, do the due diligence and read it. These can also be a great source of material for questions, but more importantly, it is unprofessional to ask the same questions that have already been posed to the candidate. This is partly because you won't learn as much from repeated questions, but also because the candidate will be bored or unimpressed going over the same ground. Great candidates want to be challenged, and an interview team where people are asking the same questions makes the candidate think the team is disorganized or unimaginative.

3. Use calibrated questions

Interviews are not the time to try something new. Take the time to do new problems on your own or test them on your peers. Come to the interview with questions that you were given in your interview (since you certainly will know how well you did) or that you have already given to others. Testing new material can really hurt a candidate's chances for success or, worse, give him or her a bad impression of the company when you aren't prepared to answer clarifying questions. You get the most from interviews when you can compare the results of one with another, particularly with the results of a successful hire or peer—so try to come to the interview with questions that will help you make this comparison.

4. Test new questions on yourself and your peers

If you do have a new question you want to give a dry run, have someone ask you to answer it. Where do you get hung up? How long does it take you? If the problem is too familiar to you to assess it, ask one of your teammates to be your guinea pig (as a manager I often offer to be the interviewee for my team to test out new questions; after all, isn't it fun to turn the tables and interview your manager?). Seeing where the people you know and respect get stuck, or how long they take to solve it, will give you a good baseline for comparison with future candidates.

5. Create a timeline for the interview

You should walk into every interview with a schedule: what questions you plan to ask and how long each should take. Each question should have clear goals and focus on specific competencies for the position. Ideally, the questions should be different from one another and give you a feel for multiple areas of the candidate's experience and background. I like to ask about five questions, so a typical agenda might look like this:

• Warm-up question about the candidate's background (or common interest) -- 5-10 minutes

• Problem-solving question that involves coding of some sort -- 10-20 minutes

• Design question -- 10-15 minutes

• Two to three cultural or situational questions -- 5-10 minutes

• Time to answer the candidate's questions

6. Head in with a positive attitude

You want the candidate to have a good experience with the company and your process. If you are upbeat, it is much more likely a qualified candidate will accept the position. If you aren't, people talk and it is a small world. You want candidates to think well of the company and feel they were treated fairly. It's like karma—what goes around comes around. To ensure this happens, try to make your questions and hints feel collaborative, and whatever you do, don't insult any candidates or make them feel stupid. They are probably nervous and you already have the job—there is nothing to prove, so make an effort to give them a fair shot.

7. Take notes

Seems obvious, but so many people don't take notes. Even if you have a photographic memory, taking the time to write down a few things here and there will indicate to the candidate you are paying attention and are genuinely interested in what he or she has to say. As an avid note-taker, here are some of my favorite tips:

• Try not to use a laptop. Yes, it is probably faster and more efficient, but it can be a physical divider between you and the candidate, not to mention offputting. When an interviewer uses a computer during an interview, it is easy to think that he or she is not paying attention to what the candidate has to say.

• Instead of writing code/drawings on a whiteboard, try paper. This may be more comfortable for most people than standing up at a whiteboard, and you can take the paper with you—which is better than any copied whiteboard code.

• Don't write notes on the resume. Someone once told me that in some cultures business cards and resumes are considered a reflection of the person, and writing on them can be insulting. While I personally haven't encountered anyone who felt this way, I am sure never to do this (and bring my own paper) just in case.

8. Bring a list of questions to the interview

No candidate will think less of you for coming in with written questions, and in fact some may appreciate that you prepared the same way they did. This will also help you establish your game plan and agenda so you don't forget. Another one of my favorite tips is always to have spare questions for really good interviews (that get through all the material quickly) or for bad interviews (where you don't want to ask your prepared questions because they are too hard).

9. Be collaborative

You want the candidate to be successful, so try to approach a problem together. I know many other managers who have moved to a pair programming model where the interviewer and the candidate code a problem together in an editor or Google doc.

10. Try to make the problems feel as real-world as possible

Smart people want to be challenged. They also would love to get a taste of what it is like to work at your company. Do your best to come up with questions that at least hint at some of the problems you might solve (or problems that relate to the underlying theory of the work you do).

Of course, there is no right way to do an interview, but you can always be better. Make an effort to make your candidates as comfortable as possible so they have the greatest chance for success. Happy hiring!


Related Articles

Interviewing Techniques
- George Neville-Neil
Separating the good programmers from the bad
http://queue.acm.org/detail.cfm?id=1998475

Nine Things I Didn't Know I Would Learn Being an Engineer Manager
- Kate Matsudaira
Many of the skills aren't technical at all.
http://queue.acm.org/detail.cfm?id=2935693

10 Optimizations on Linear Search
- Thomas A. Limoncelli
The operations side of the story
http://queue.acm.org/detail.cfm?id=2984631


Kate Matsudaira is an experienced technology leader. She worked in big companies such as Microsoft and Amazon and three successful startups (Decide acquired by eBay, Moz, and Delve Networks acquired by Limelight) before starting her own company, Popforms (https://popforms.com/), which was acquired by Safari Books. Having spent her early career as a software engineer, she is deeply technical and has done leading work on distributed systems, cloud computing, and mobile. She has experience managing entire product teams and research scientists, and has built her own profitable business. She is a published author, keynote speaker, and has been honored with awards such as Seattle's Top 40 under 40. She sits on the board of acmqueue and maintains a personal blog at katemats.com.


Copyright © 2017 held by owner/author. Publication rights licensed to ACM.

acmqueue

Originally published in Queue vol. 15, no. 3
Comment on this article in the ACM Digital Library





More related articles:

Abi Noda, Margaret-Anne Storey, Nicole Forsgren, Michaela Greiler - DevEx: What Actually Drives Productivity
Developer experience focuses on the lived experience of developers and the points of friction they encounter in their everyday work. In addition to improving productivity, DevEx drives business performance through increased efficiency, product quality, and employee retention. This paper provides a practical framework for understanding DevEx, and presents a measurement framework that combines feedback from developers with data about the engineering systems they interact with. These two frameworks provide leaders with clear, actionable insights into what to measure and where to focus in order to improve developer productivity.


Jenna Butler, Catherine Yeh - Walk a Mile in Their Shoes
Covid has changed how people work in many ways, but many of the outcomes have been paradoxical in nature. What works for one person may not work for the next (or even the same person the next day), and we have yet to figure out how to predict exactly what will work for everyone. As you saw in the composite personas described here, some people struggle with isolation and loneliness, have a hard time connecting socially with their teams, or find the time pressures of hybrid work with remote teams to be overwhelming. Others relish this newfound way of working, enjoying more time with family, greater flexibility to exercise during the day, a better work/life balance, and a stronger desire to contribute to the world.


Bridget Kromhout - Containers Will Not Fix Your Broken Culture (and Other Hard Truths)
We focus so often on technical anti-patterns, neglecting similar problems inside our social structures. Spoiler alert: the solutions to many difficulties that seem technical can be found by examining our interactions with others. Let’s talk about five things you’ll want to know when working with those pesky creatures known as humans.





© ACM, Inc. All Rights Reserved.