Here are some thoughts for students who are considering computing, including computer science and software engineering, as a career. While these tips are particularly geared for high schoolers going to my alma mater, Monta Vista High School, they can apply to many others.
What do I enjoy about computing?
Computers are capable of doing amazing things, but in reality, they’re really dumb. You have to give them precise instructions on how to do something. If you get it wrong, they can’t guess what you want them to do. I find taking a task, breaking it down into smaller pieces, writing instructions to do those small tasks, and putting it all back together inherently satisfying. You get a sense of mastery by getting a sophisticated piece of equipment to do what you want it to do.
I also enjoy the fact that my work has a direct impact of millions of lives. Every time someone searches for something on Google, code that I have written is executed. I certainly feel like I am making a difference.
My typical workday
As a software engineer at Google, my day is not just about sitting in front a computer monitor, pounding out “code” (the instructions that tell the computer what to do). The image of the solitary hacker is a myth.
Before writing any new code, I need to consider how it will work with code that Google already has. It’s like building a structure — you could slap your addition onto an existing building, but that could destabilize the whole structure. Or you can carefully design your addition so that it integrates well with what is already there.
So I will meet with my colleagues to discuss the problem I’m solving and how I intend to solve it, either face-to-face or through e-mail. I may also write a design document that gives all of us one document to refer to.
Sometimes I write code with a colleague, especially if the code is tricky. This process, called pair programming, lets one person type while the other looks up documentation or spot errors on the fly. It can be intense but also more fun, since you’re sharing your joy (and pain) with someone else. It also reduces distractions, since you can’t check your e-mail while your partner is waiting.
Once I’m done writing a piece of code, I then need to integrate it with the existing code. But before I can do that, another software engineer must review the code that I wrote. He or she may (and probably will) point out bugs that I need to fix before integration. I also review the code of other engineers.
Our project team has short status meetings everyday, which last five to ten minutes. Our larger group has status meetings every week, which often last only fifteen minutes. I also attend other one-off meetings about design issues that affect our whole group, and I answer questions that other engineers may have about the work our team is doing.
So a lot of time is spent designing, reviewing, and communicating my ideas with others, not just programming.
Now you’re interested in pursuing computing as a career. How do you start?
Before College
A straightforward way to try out computing is to take AP Computer Science in high school. Since the test uses the Java programming language, you may want to also take the Java programming class that Monta Vista offers, the year before taking AP Comp Sci.
However, suppose you don’t find either the Java class or the AP Computer Science class that interesting, but you’d still like to explore computing. Don’t give up! There are plenty of alternative approaches to learning how to program, a fundamental skill in computing (but not the only one), which you can try on your own. You can also try these before going into AP Comp Sci.
Instead of Java, you could choose another language like Python, which has many conceptual similarities with Java but is less verbose. There are a few tutorials for learning how to program using Python, such as A Byte of Python or Learn Python the Hard Way (I have not tried either of these myself).
There is also an interactive website for learning how to program called Codecademy.
If you’d like to learn programming in the context of a more visual and dynamic environment, Processing is a popular language for creating visual art and animation.
There are several other systems that lets novice programmers create games and visual simulations. These include:
The key is to try these out, experiment, and have fun with it. It will take some time and persistence, but the rewards are well worth it.
By the way, you still have to pay attention to your other classes. Besides math and science, writing and speaking are the most useful skills in your career. If you can’t get your point across to your colleagues, your great ideas will never be accepted.
College
There is widespread agreement on the top four computer science university programs (in no particular order): Carnegie Mellon, MIT, Stanford, and UC Berkeley. However, there are plenty of great CS programs all over the country, including (but not limited to) Brown, Caltech, Cornell, Georgia Tech, University of Illinois at Urbana-Champaign, University of Texas-Austin, University of Washington, and University of Wisconsin-Madison. It’s hard to go wrong with any of them, so you should also pick a college based on your own personal preferences, such as small liberal arts school versus large research institution.
There are many different ways to teach computer science. For example, Carnegie Mellon, Harvey Mudd, and Georgia Tech design their programs to attract and keep women and underrepresented minorities to computing, which the field desperately needs.
No matter where you go, I highly recommend doing summer internships. These are becoming more and more important for getting a job after college, or for getting into graduate school. Internships expose you to how different companies operate and give you some real world experience.While I was in college, I did two summer internships (IBM and Microsoft).
If you’re considering graduate school, I also recommend doing undergraduate research work if your university offers the opportunity. For example, Caltech has Summer Undergraduate Research Fellowships.
Graduate School
Unlike other science and engineering fields, getting a Master’s or PhD degree in computer science does not automatically mean you will be earning more money or have higher job status than those with a Bachelor’s degree. However, attending graduate school, especially a PhD program, gives you different types of opportunities than a college graduate.
Getting a PhD in computer science means you want to deeply explore a specific topic within a specialty of computer science. This means that the school you will apply to will depend on what specialty you want to go into, such as artificial intelligence or operating systems. For example, the University of Wisconsin-Madison has an excellent program in databases but is not a great choice for human-computer interaction.
By the time you get your PhD, you will know lots of leading figures in academia and industry in your specialty. Networking becomes a key skill that you learn. You also learn how to figure out what questions are still unanswered in your field, and address it in a way that no one else has before. It sounds a little daunting, but that’s what graduate school is for.
In fact, throughout graduate school you come to realize that there are lots of questions out there, and the real problem is how to pick a problem that you can reasonably answer in a few short years, so you can graduate. Persistence and endurance, more than sheer intelligence, is the key to getting a PhD.
Once you have a PhD, you have the opportunity to get a job where you can look farther out in the future than most people, especially if you become a professor or join a research lab at a company like Microsoft or IBM. These jobs are nearly impossible to get without a PhD. But at the same time, you will become “overqualified” for jobs that only need a Bachelor’s degree. So getting a PhD changes your opportunities, but it doesn’t necessarily broaden them.
Give it a shot
I hope you consider computing as a career. It’s rewarding and satisfying in its own way, and the fact that it’s also in high demand is just a bonus. Even if you decide to do something else later, the skills you learn in computing will serve you well. Good luck!
Hey Jimmy,
This is a great core description of computing as a career. If I may riff on a few things and add a few different perspectives for the benefit of anyone reading…
For any of you Monta Vista folks… I’m a Homestead graduate, the same year as Jimmy, and we went to Caltech together. I ended up getting a masters degree and I’m now a co-founder and chief software architect at a Seattle startup, a much smaller company than Google.
My typical workday is fairly similar to Jimmy’s, with the primary difference that I’m also involved in a lot of decision making related to our products– what the product will do, not just how it will be written. I’m probably involved in more meetings, which is unfortunate but necessary at an early stage company.
Another aspect of my job is that I’m constantly evaluating outside pieces of code (called “libraries” or “services”) that we may want to incorporate into our software. When you’re writing software, you often have the choice between building something yourself, and using someone else’s system (which may or may not involve paying them for it). As a simple example, for our product, we have to send email to many of our users fairly regularly to update them on the status of their accounts. For that, we chose to use Amazon Web Services, which can handle all the nitty gritty details of sending lots of email (which is actually more complicated than we might think). We have to pay Amazon for the service, but it frees our time up to work on other things. So a major component of my job is to learn about these external pieces of code, understand what they do and how they do it, so that I can make decisions about what we should use.
On the question of what to do before college to prepare for a computing career, I agree that you probably should learn Java, but that’s only out of grudging necessity if the AP Computer Science test uses it. My opinion is that Java is a poor language for learning to program, for a variety of reasons I won’t go into here. If you really want to get ahead, the language you should consider learning is Lisp, or a closely related language such as Scheme or Logo. There’s a lot of fun material available for these languages (one of my favorites is a book called Land Of Lisp by Conrad Barski). Do Lisp for six months before jumping into Java, C, or Python, and it will give you a much better foundation to be a good programmer.
Another tip: if you’re learning any kind of music (or if, more likely, your parents have forced you to take lessons), don’t stop. Your music will probably help your programming. There’s a somewhat mysterious but well-known connection between music and programming, something to do with the fusion of the mathematical and creative elements. Most of the best programmers I know are also musicians.
Finally, on the question of how much schooling you should do, there are a lot of opinions. Jimmy went all the way through his PhD, and if you want to do research or teaching, that’s pretty much a requirement. But if you just want an exciting career as a software engineer, I actually recommend against a PhD. I think it’s overkill. It takes forever, and it often sends the wrong message to potential employers about your expectations. And, in my experience, most PhDs I’ve worked with have actually developed some very bad coding habits that are difficult to break because they’ve spent too much time coding by themselves rather than working within the structured environment of a software company. My advice is, unless you’re certain from the outset that you want to go into teaching or research, go work for a company for three or four years before deciding whether to start a PhD.
I think a master’s degree is a good sweet spot if you just want to beef up your education before going to work. A master’s will generally broaden your opportunities without closing any doors, whereas a PhD will generally open some doors and close others.
Don’t be tempted to drop out of college, though. Yes, you hear stories about the Bill Gateses of the world who dropped out of college, started companies and became billionaires. But those days are over. Computing systems today are much more complicated, and change much more quickly. In order to succeed now, you will need the background you will get in your college computer science program.
Finally, as a programmer, you should expect to be a lifelong learner. We’re in an age where technology changes extremely rapidly, with industry-shaking advances happening pretty much every single year. Learning to learn, practicing your learning skills, is a must in order to keep up.