Hiring good programmers - Part 1
Published on: 2010-05-22
One thing that I've struggled with, and I know I'm not alone, is how to accurately determine if someone will be a good programmer for a company or not. I'm sure you're aware of the traditional process: companies will first screen resumes, looking for particular experience, skills, etc. They will next have a phone screen to further weed out candidates. Finally, the candidates will be brought in for a face-to-face interview. How effective are these methods, and what can we do to be more effective? In Part 1, I will outline issues with common current methods of evaluation, and in Part 2, I will suggest an alternative.
Let's start with screening resumes. Many companies will pre-rank candidates (either explicitly or implicitly) based on the quality of the resume and the information presented on it. There are a few problems with this. First, I have read (and unfortunately I don't recall where) 50% of people lie on their resume. 50%! Couple with the proliferation of sites, such as fakeresume.com, that are intended to give advice to people who want to get away with lying on a resume, it's tough for employers to know which resumes to trust. Second, many of your potential employees will have hired a professional resume writer in order to get your attention. Great resume? Is it because they are a detailed worker or just hired a great resume writer?
What about a degree? Most of the jobs posted on the major job sites for programmers ask for some sort of technical bachelor's degree. This certainly should be a consideration for an entry-level candidate. However, in observing a number of people in a number of different industries, I've come to the conclusion that the benefits of the quality or type (or even presence) of a degree decreases severely after about 1-3 years of experience. For experienced candidates, the ability to learn new concepts and apply those concepts in new situations becomes a much more important asset than the quality or source of their original education. Putting it in another way, does the candidate have 10 years of experience, or 1 year of experience repeated 10 times? In fact, I might be more inclined to hire the person with the poor quality of education who somehow managed to become a good programmer, since they have the proven ability to learn and apply concepts in less than ideal circumstances.
What about the interview? A lot of good information can be gotten from an interview, but a lot of misleading information can be gotten here, too. It's tough to know which questions to ask, and questions that aren't directly related to the job are all too common. To see why that's problematic, here's an example from an article I read on BNET that quoted a hiring manager saying (and I'm paraphrasing) that they hired someone based on the answer to this question: "If you would be a character from 'The Wizard of Oz', which would you be and why?" What can you learn from the answer, assuming you get one?
- The interviewee thinks well on his or her feet and handles the unexpected well
- The interviewee has an active fantasy life and empathizes with characters easily
- The interviewee is a huge 'Wizard of Oz' fan
- The interviewee doesn't know or doesn't care that the question is irrelevant to the position, likely pointing to the fact that the interviewee doesn't think for himself/herself
- The interviewee does not have the ability to sense when something is or is not a waste of time and would be a poor choice for leadership positions
You could legitimately make a case for any of the five. #1 is definitely a plus for your company, #2 may or may not be, depending on the position, culture, and point of view, #3 is completely irrelevant, and #4 and #5 would be considered negatives for most positions out there. I can't see how the interviewer in this case learned anything worth knowing from this question given the uncertainty involved.
Finally, many companies have some sort of programming exercise as a part of the interview processes. In general this is a good method, but a poorly designed exercise may not deliver the desired results. For example, what does having the programmer show all the prime numbers from 1 to 100 show about his or her ability? Unless you're dealing with mathematics-heavy code fairly often, the results of this test probably aren't indicative of their fit into your organization.
In Part 2, I will demonstrate some methods for getting at the heart of the job position which will hopefully make it easier to scan resumes, design interview questions, and design programming exercises.