2004-07-08 15:59:32
Hazards of Hiring
Summary: Eric offers guidelines for handling tough hiring decisions in a small ISV.
Several months ago, I wrote an MSDN column entitled Make More Mistakes. This column was one of the most popular things I have ever written. People seemed to really enjoy reading about my screw-ups. As human beings, we are fascinated by the failures of others.
In the many e-mails I received about that column, one of the most common questions was why didn't I list any hiring mistakes. "Eric, is it possible that you have simply never made a mistake in a hiring decision?"
Au contraire, I've made plenty. But those are stories I would rather not tell. It is one thing for me to air my own idiocy in public, but quite another thing for me to recount tales that might hurt someone else.
Nonetheless, hiring decisions are tricky, and I think I've learned enough to say a few worthwhile things on this topic.
I'll start with four general guidelines for how to proceed with a hiring decision.
After that, I'll finish the article by saying a few things about the specific challenges of hiring software developers.
1. Hire After the Need, Not Before
The first step in hiring is to make sure that you actually need to be hiring. For small independent software vendors (ISVs), my rule is: Don't fill a position until after the need for that position is painfully clear.
In other contexts, it often makes sense to "staff up" in anticipation of growth. Many venture-capital-funded companies work this way. Your investors didn't give you millions of dollars because they want their cash sitting in your bank instead of their own. They expect you to grow your company aggressively, and that often means hiring more staff.
But in a small company that is funded by its own revenues, it is almost always a mistake to hire for a position before it is absolutely clear that hiring is the right thing to do.
This is an easy mistake to make. Version 7.0 of your product is going to ship in 8 weeks. You are expecting lots of new orders, so you decide to hire another customer service person to be ready for the deluge of phone calls.
Better idea: Have one of your existing staff take those calls, or take them yourself. Don't increase your payroll until you are 100% certain that you have a permanent need for one more person than you have now.
Several years ago, I decided to get very aggressive about growing SourceGear "to the next level". We made several new hires, including a human resource (HR) person. We convinced ourselves that the company was going to be growing so fast that we needed an HR person to help coordinate policies and benefits. We hired a top-notch individual for that job. Let's call her Wilma.
Wilma was a dear friend of mine and still is. She did a fine job for us here at SourceGear.
But the fact remains that our company was not really big enough to have a real need for a full-time person in HR. We knew this, but we were "staffing up for growth". And then the dotcom bubble burst, and SourceGear never did get that big.
2. Realize That Hiring Is All About Probabilities
Hiring is all about probabilities. When we evaluate a candidate, we are basically just trying to predict whether that candidate will be a success in the position being filled. We're trying to know the future, but we have no prophets and no Oracle.
So, we use various indicators that we believe will be correlated with future success. We look at past experience. We look at educational background. We call references.
But there are no certainties. Sometimes all our indicators are positive, but the employee just doesn't work out. Last year I helped a charitable organization hire a new staff member. We found a candidate with an incredibly solid résumé. Let's call him Wilbur.
We interviewed Wilbur at considerable length. We checked his references. There was no question he had the necessary experience to handle the job. The decision seemed clear, so we did the hire.
Shortly after Wilbur started on the job, things turned surreal. Was this the same guy we hired? The chemistry between him and the team was a nightmare. Wilbur is clearly a sharp guy with solid abilities, but this situation simply didn't work out at all.
On the other side of the coin, sometimes we miss out on a great employee because our indicators steered us away. Most of the time, we never know about these situations. We turn down a candidate, and we don't hear where that person ends up. Some of them go on to be a big success.
3. Know the Law
In the United States (and probably elsewhere as well), there are laws that you need to know before you even start the process of trying to hire someone. There are federal statutes and there may be state and local regulations as well. I am not an attorney, so I will not even attempt to explain these laws, but it is very important that you understand them.
The various materials from Nolo Press are usually a good starting point for beginning to understand legal matters. Nolo Press has a Web page on employment law that has lots of information. Even still, it is always advisable to consult a local attorney.
One final remark: Even if you discover that you are exempt from the laws due to the small size of your company, it is well worth your time to understand the law and begin making habits out of following them. In most situations, complying with the discrimination laws will actually improve your decision-making anyway.
4. Get a Variety of Opinions
The general principle here is that good decisions happen when you have several different perspectives. If you want to consistently make the worst hiring decisions you can make, just make all the decisions by yourself without listening to anybody else.
But if you want wise decisions, get a variety of opinions and different perspectives. In my own hiring decisions, I make sure at least one of those perspectives comes from a woman in my company.
The simple fact is that the software industry has a lot more men than women. Julia Lerman noticed that the Tech-Ed speakers list had more people named Brian than women. Our field is perhaps 90% male, and that means I have to work a little harder to get balance on this aspect of our hiring decisions.
I've observed a pattern over the years, and of the bad hiring decisions we've made, many of them happened when the decision was made entirely without a woman's voice.
Fortunately, my approach has worked well in ways that I could not have anticipated. In 1998, SourceGear was looking to hire a full-time person in technical support. The decision was primarily being driven by myself and one of my co-workers named Mary. We interviewed several candidates. Mary and I disagreed on which candidate should be chosen. I deferred the decision to Mary, confident that I would eventually be proven right. But the person Mary chose turned out to be one of the best employees we've ever had.
Hiring Programmers: The Usual Advice
Most of the writings on the subject of hiring programmers tend to sound the same. The usual advice is to "only hire the very best".
I'll confess that I'm not terribly fond of this advice. It is simply too vague.
Please understand that I am not advising anyone to deliberately seek out mediocrity. We obviously want to hire the most talented and experienced people we can. In a hiring decision, the stakes are high. Your decision will affect your team, and it will affect the individual. As Joel says, "It is much better to reject a good candidate than to accept a bad candidate. ... If you have any doubts whatsoever, No Hire."
But the usual advice still annoys me. The problem isn't so much with the advice itself, but with its tendency to be misunderstood. When applied with no additional precision, the primary effect of the usual advice is to create a sense of arrogance. This effect is especially common among programmers, since elitism comes naturally to us anyway. When we hear that we should "only hire the very best", we internally translate this to mean:
The "very best"? Why, that's me! I am the "very best". Obviously, I should only hire people who are as gifted, as smart, and as good-looking as I am. After all, why should I pollute my perfect team with riffraff?
It is not surprising that this attitude provides a poor framework for hiring decisions. The usual advice works much better when it is understood quite differently:
I want to build the most effective team that I can build. When I hire another person for my team, my goal is not merely to make the team larger. Each person I hire should be chosen to make my team better in some specific way. I am not looking for someone as talented as me. Rather, I am looking for someone who is more talented than me, in at least one significant way.
The very worst kind of manager is the one who feels threatened by his team. Consciously or not, he is afraid of those who are "the very best", so he consistently staffs his team with people who will not challenge him.
I suppose he might be able to get away with this in a big company. After all, I doubt that the Pointy Haired Boss in the Dilbert comic strip was created with no source of inspiration at all.
But things are very different in the world of small software companies. If you are the founder or "chief geek" in your small ISV, take a careful, honest, and objective look at yourself. If you are the type of person who feels threatened by your own staff, stop and rethink. Until you move yourself past this problem, you have exactly zero chance of building an effective team.
The real point of the usual advice is not to inflate our egos--it is to remind us that we should not be afraid to search for the best people.
But we still need a more specific understanding of what the word "best" really means.
Look for Self-Awareness
The "very best" people never stop learning.
When I evaluate a candidate, one of the most important criteria is what I call "the first derivative". Is this person learning? Is this candidate moving forward, or have they stagnated? (For more of my thoughts on this topic, see the Career Calculus article on my weblog.)
People who are seriously focused on their own future success are very likely to be successful. This is often the strongest predictive indicator in the hiring process.
I'm not saying you should just hire people who want to succeed. Everybody wants to succeed. I'm talking about hiring people who are serious about constant learning. These people don't spend their time trying to convince you of how much they know. They don't focus on their past very much. They are always focused on their future. As you interview them, they are interviewing you, trying to figure out how much they can learn from you.
How do you find this kind of person? It turns out that this posture has a precondition that is rather easily observed: People who are committed to constant learning are people who know what they don't know. They know their own weaknesses, and they're not insecure in talking about them.
One of the popular interviewing questions is to ask the candidate to describe their biggest weaknesses. Even though this question is terribly "old school", I really like it.
Unfortunately, most candidates try to duck the question. They go to their local bookstore and they buy a book on interviewing. That book warns them that I am going to ask this question. The book tells them creative ways to avoid giving a genuine answer:
- Sometimes I work too hard.
- Sometimes other team members get frustrated with my attention to detail.
When I ask candidates to tell me about their weaknesses, I am hoping for a wise, honest, and self-confident answer. When I hear a candidate rationally admit a weakness, I am impressed. When I hear a candidate duck the question with language straight out of a book, I start thinking about the next candidate.
Hire Developers, Not Programmers
For a small ISV, the "very best" programmers are the ones who can do more than just write code. You should hire developers, not programmers.
Although the words "developer" and "programmer" are often used interchangeably, I make a distinction between them. That distinction is the difference between simply coding and being a part of product team.
I wrote an article on this topic on my weblog, from which I quote:
For the purpose of this article, a "programmer" is someone who does nothing but code new features and [if you're lucky] fix bugs. They don't write specs. They don't write automated test cases. They don't help keep the automated build system up to date. They don't help customers work out tough problems. They don't help write documentation. They don't help with testing. They don't even read code. All they do is write new code. In a small ISV, you don't want any of these people in your company.
Instead of "programmers" (people that specialize in writing code), what you need are "developers" (people who will contribute in multiple ways to make the product successful).
What does the usual advice really mean? Exactly what attribute do I measure to determine if the candidate is "the very best"?
Most of the time, the usual advice is understood to apply only to coding skills. It really is true that the best coders are gifted with an aptitude. They understand things that generally cannot be taught. They are perhaps ten times more productive than average coders. It obviously makes good sense to try to find one of these "10X" individuals, especially in larger environments where specialists like pure coders can fit in well.
But in a small ISV, we need versatility. We often need the people on our teams to wear multiple hats, not just write code. In these cases, it is often very important to look for the best developer, and that person is not necessarily the best programmer.
Education Is Good
People with a solid education in the fundamentals often turn out to be the "very best" developers.
The issue of education is quite controversial in the software field. Right now, somewhere on the Internet, there is a discussion board or a chat room where people are arguing about how much education is needed to be a software developer. The arguments go on, all day, all night, 365 days a year, and they never find the answer to the question.
And they never will. Hiring is about probabilities. Educational experience is an indicator that can be used in predicting success, but it is not always accurate.
Two of SourceGear's best developers have no degree. One of them is an excellent programmer who is gradually becoming an excellent developer. The other is an excellent developer who is gradually becoming an excellent programmer.
Nonetheless, I still sort résumés by educational level. These two developers are exceptions from the norm. The bulk of my experience has taught me that a college degree is a useful predictor of future success. When I hire developers, I want to see a bachelor's degree from a highly regarded computer science department. Yes, yes, I have two obvious counterexamples right here among my co-workers. But hiring is about probabilities. When I see a BS from someplace like University of Illinois or Stanford, I believe the probability of ending up with a successful employee in the future is higher.
But Too Much Education Is a Yellow Light
On the other hand, when I see a Ph.D. in computer science, I believe the probability goes down.
Universities don't teach people to be developers anyway. They don't even teach people to be programmers. Universities teach their students to be computer scientists. Becoming a programmer or even a developer is usually left as an exercise for the student to complete on her own time.
A bachelor's degree gives you a solid grounding in fundamentals and it proves that you can finish. Those issues are important, but when it comes to the specific set of skills we need in a small ISV, you are approaching the point of diminishing returns on your first day of graduate school.
People tend to get terribly offended by these opinions. Please understand that I do have a lot of respect for people who have finished a Ph.D. It takes a tremendous amount of discipline, intelligence, and desire to finish a doctoral degree. I admire those "Ph.D. Qualities". I seriously doubt whether I could finish a Ph.D. myself.
But I still believe that those "Ph.D. Qualities" are not the same skills that are needed in a small ISV. Shipping a shrinkwrapped product requires a different kind of discipline, intelligence, and desire. These "Shrinkwrap Qualities" are similar to "Ph.D. Qualities", and yet are very different.
Furthermore, I believe that very rare is the person who has both Ph.D. Qualities and Shrinkwrap Qualities. Some people have the talents to finish a Ph.D. Some have the talents to finish products. Some people have both, but not very many people. When I see someone who has finished a Ph.D., I know for certain that they have Ph.D. Qualities. I will therefore consider it unlikely that they have Shrinkwrap Qualities as well.
Obviously, I may be wrong, but hiring is all about probabilities. We use guidelines to predict the future success of a candidate, but those guidelines are not always correct. There are exceptions to every rule, and playing the odds will cause me to miss out on those exceptions. That's unfortunate, because a Ph.D. with Shrinkwrap Qualities would be an incredible person. Suppose, for example, that I received a résumé from somebody with a Ph.D. in computer science and with several years of experience as a developer on the Adobe Photoshop team. Obviously, I would want to interview this person. I don't think there is a shrinkwrap product I admire more than Photoshop. Ph.D. or not, this person clearly has Shrinkwrap Qualities. The Ph.D. is not inherently negative. It is merely a predictive indicator, and sometimes it's wrong.
Look At the Code
Although I do place a high value on the non-coding aspects of software development, the code is important, too. The "very best" developers still ought to be darn good programmers.
Don't be afraid to look at the code. When you interview developers, ask for code samples. Ask them to write some code during the interview.
One of my favorite questions is to ask candidates how many lines of code they have written in their entire career. The answers vary widely. Some people don't even know. Some people tell me it's a stupid question and spout all the research showing that "line count" isn't a terribly good measure of programmer productivity. Fine, I'll stipulate to all that, but I still like the question. I believe that people tend to become better programmers as they write more and more code. I want to know how much code you've got behind you.
During college I wrote a C compiler, just for fun. It was written in C, entirely from scratch, with a handwritten recursive descent parser. I even did some peephole optimizations on the back-end. It wasn't very fast, but it could compile itself with no errors. I released it under the GPL, but I was only the person who ever used it.
When I applied for a developer job at Spyglass, I showed my compiler
to the hiring manager. I got the job, and my compiler project was one
of the factors in his decision. He said he looked at my code and
realized that I had already gotten a lot of the bad code out of my
system, so my next hundred thousand lines of code ought to be pretty
good. :-)
Twelve years later, I think there is some wisdom in hiring people who have made significant contributions to an open source community project. After all, I don't have to ask for code samples, I can just grab a tarball and read it myself.
But the availability of code for review is one just minor reason why I like to see open source experience on a résumé. Working on this kind of project also says something about the person.
Granted, a lot of these coders are driven purely out of hatred for Microsoft. Regardless of your opinions about Microsoft, that kind of motivation is not likely to be a good foundation for success in any developer job.
But a lot of people work on an open source project simply because they have a passion for coding. It's their hobby, and as hobbies go, it's not a bad one. Some folks look at projects like AbiWord or ReactOS and all they see are people who are wasting their time by cloning mature Microsoft products. I'll concede that these projects don't make much sense if you're trying to find a business case for them. But the typical contributor to these projects is coding for fun. Watching TV is a waste of time. Coding is not.
People who genuinely love to write code often turn out to be the "very best" developers.
The Very Best
It turns out that the usual advice works just fine, but we have to move from the vague to the specific. To summarize the various points I made in the sections above, here are ten questions to ask yourself when considering a candidate for a developer position:
- Can this candidate bring something to the team that nobody else has?
- Is this candidate constantly learning?
- Is this candidate aware of his/her weaknesses and comfortable discussing them?
- Is this candidate versatile and willing to do "whatever it takes" to help make the product successful?
- Is this candidate one of those "10X coders"?
- Does this candidate have a bachelor's degree from a good computer science department?
- If this candidate has a Ph.D., is there other evidence to suggest that s/he is one of those rare people who also has "Shrinkwrap Qualities"?
- Does this candidate have experience on a team building shrinkwrap software?
- Does this candidate write good code?
- Does this candidate love programming so much that s/he writes code in their spare time?
It's not necessary to answer "yes" to all ten of these questions. I'm not even going to specify a minimum number of "yes" answers needed for a positive hiring decision. Hiring is all about probabilities, and each of these questions can serve as an indicator to help you predict whether the candidate will be a success for you.
In the end, every hiring decision will be made with your own judgment, and there are no guarantees. However, giving consideration to these issues can help raise the probability of making a hiring decision that you will not later regret.
Eric Sink is the non-legendary founder of SourceGear, a developer tools ISV located in Illinois. Recently, Eric was delighted to hear that his Make More Mistakes column was used by someone on the Microsoft.com Web team as an example of a really bad title. The title for this month's piece was chosen specifically in the hope that he might earn this dubious distinction once again. :-) If you appreciate this kind of warped sense of humor, check out Eric's weblog at https://ericsink.com/.
This article originally appeared on the MSDN website.