97

I'm working at my first programming job. My boss is a very smart software engineer, and I feel like I have very little to offer compared to him. Problem is, he is always busy, and needs someone to help him out. I feel like I'm not good enough, but I still want to succeed. I want to be a great programmer.

What can I do to impress him?

Thank you.

yannis
  • 39,547
  • 40
  • 183
  • 216
Pablo
  • 827
  • 1
  • 8
  • 12

21 Answers21

188

Did I ever tell you about Ashton?

Ashton was your classic corn-fed farm boy. His parents had been hippies who never really managed to get their acts together until his mother inherited 15 acres in a rural part of Michigan. The family moved out there, bought a couple of dairy goats, and struggled to make a living selling organic goat cheese to the yuppies at the Ann Arbor Farmer’s Market.

From the time he was ten years old, Ashton had to wake up every morning at 4:00 a.m. and milk those damn goats, and it was exhausting. Ashton loved going to school because it meant he wasn’t working knee-deep in goat poop. Throughout high school, he studied his ass off, hoping that a scholarship to a good university would be his ticket out of the farm. He found college to be so much easier than farm life that he didn’t understand why everyone else didn’t get straight A’s like him. He majored in Software Engineering because he couldn’t imagine engineers ever being required to wake up at 4:00 a.m.

Ashton graduated from school without knowing much about the software industry, really, so he went to the career fair, applied for three jobs, got accepted by all three, and picked the one that paid the most: something insane like $32,000 a year, working at a big furniture company in the southwestern part of the state that manufactured cubicle farms for corporations all over the world. He never wanted to see a farm again, so he was determined to make a good impression on his boss, Charlie Sherman.

“That’s not going to be easy,” his cubicle-mate, Jeff, said. “She’s something of a legend here.”

“What do you mean?” he asked.

“Well, you remember a few years ago, when there was all that uproar about Y2K?”

Ashton was probably too young. “Y2K?”

“You know, nobody expected that all the old computer programs written in the 1960s would still be running in 2000, so they only had room for two digits for the year. Instead of storing 1999, they would store 99. And then when the year flipped over on January 1st, 2000, the computer systems crashed, because they tried to fit “100” in two digits.

“Really? I thought that was a myth,” Ashton said.

“At every other company in the world, nothing happened,” Jeff said. “They spent billions of dollars checking every line of code. But here, of course, they’re cheap bastards, so they didn’t bother doing any testing.”

“Not at all?”

“Zilch. Zero testing. Nada. And lo and behold, when people staggered back into work on January 2nd, not a single thing worked. They couldn’t print production schedules. They couldn’t get half of the assembly lines to even turn on. And nobody knew what shifts they were supposed to be working. The factory literally came to a standstill.”

“You’re kidding,” Ashton said.

“I shit you not. The factory was totally silent. Now, Charlie, she was new then. She had been working at Microsoft, or NASA, or something... nobody could figure out why someone like her would be working in our little armpit of a company. But she sat down, and she started coding. And coding. And coding.

“Charlie coded for nine days straight. Nine days without sleeping, without eating, some people even claimed she never went to the bathroom. She went from system to system and literally fixed all of them. It was something to behold. My God, there were COBOL systems in there that needed to be fixed. The whole factory at a standstill, and Charlie is sending people to the university library in Ann Arbor to find old COBOL manuals. Assembly-line workers are standing around shivering, because even the thermostats had a Y2K bug. And Charlie is drinking cup after cup of coffee and typing like a madwoman.”

“Wow. And she never went to the bathroom?”

“Well, that part might be a little bit of an exaggeration. But she really did work 24 hours for nine days straight. Anyway, on January 11th, about five minutes before the day shift is supposed to start, she comes out of her cubicle, goes to the line printer, hits a button, and boom! out comes the production schedules, and the team schedules, and everything is perfect, perfectly formatted, using a slightly smaller font so that the “2000” fits where it used to say “99,” and she’s even written a new priority optimizing system that helps them catch up with 9 days of missed production without pissing off too many customers, and all the assembly lines start running like nothing was ever wrong, and the heat comes on, and the invoices come out printed with ‘2000’ as the year instead of ‘19100,’ and after that day, nobody found a single bug.”

“Oh come on!” Ashton says. “Nobody writes code without bugs.”

“She did. I saw it with my own eyes. The first day back they ran two days worth of cubicles without a hiccup.”

Ashton was dumbstruck. “That’s epic. How can I live up to that?”

“You can’t, buddy, nobody can,” Jeff said, turning back to his computer terminal, where he resumed an online flame war over who would win in a fight, Spock or Batman, which had been raging for over four months.

Not one to give up, Ashton swore he would, one day, do something legendary. But the truth is, there never was another Y2K. And nobody, in that part of Michigan, gave a rat’s ass about good programming. There was almost nothing for the programmers to do, in fact. Ashton got dumb little projects assigned to him... at one point he spent three weeks working on handling a case where the sales tax in one particular county was wrong because some zip code spanned two different sales tax zones. The funny thing was, it was in some unpopulated part of New York State where nobody ever bought office cubicles, and they had never had a customer there, so his code would never run.

Ever.

For two years Ashton came into work enthusiastic and excited, and dying to make a difference and do something terrific and awesome, while his coworkers surfed the Internet, sent instant messages to their friends, and played computer solitaire for hours.

Jeff, his cubicle-mate, only had one responsibility: updating the weekly Excel spreadsheet indicating how many people were hurt on the job that week. Nobody ever was. Once a week, Jeff opened the spreadsheet, went to the bottom of the page, entered the date and a zero, hit save, and that was that.

Ashton even wrote a macro for Jeff that automated that one task. Jeff didn’t want to get caught, so he refused to install it. They weren’t on speaking terms after that. It was awkward.

On the morning of his two year anniversary at the cubicle company, Ashton was driving to work when he realized something.

Not one line of code that he had written had ever run.

Not one thing he had done in two years of work made any impact on the world.

And it was fucking 24 degrees in that part of Michigan, and it was gray, and smelly, and his Honda was a piece of crap, and he didn’t have any friends in town, and nothing he did mattered.

As he drove down Lincoln Avenue, he saw the furniture company ahead on the left. Three flags fluttered in front of the corporate campus: an American flag, a flag of the great state of Michigan, and a white and red flag with the company logo. He got in the turning lane behind a long line of cars waiting to turn left. It always took four or five traffic light cycles, at rush hour, to make the turn, so Ashton had plenty of time to try to remember if any code he had ever written was ever used by anyone.

And it hadn’t. And he fought back a tear.

And instead of turning left, he went straight, almost causing an accident because he forgot that the left turn light didn’t mean you could go straight.

And he drove right down Lincoln Avenue, and got onto the Gerald Ford freeway, and he just kept driving until he got to the airport over in Grand Rapids, and he left his crappy old Honda out right in front of the terminal, knowing perfectly well it would be towed, and didn’t even close the car door, and he walked right up to the Frontier Airlines counter and he bought himself a ticket on the very next flight to San Francisco, which was leaving in 20 minutes, and he got on the plane, and he left Michigan forever.

Joel Spolsky
  • 7,074
  • 21
  • 56
  • 49
  • 1
    are you the CEO of StackOverflow? (+1 for 'classic corn-fed farm boy') – Stephen Watkins Dec 11 '10 at 05:38
  • 61
    you can't leave me hangin like this. where is Chapter 2 of this story :) – mikeal Dec 11 '10 at 06:53
  • Wow. Just wow. I can't imagine how many Ashtons there are in corporations around the world. Depressing... :) – KristoferA Dec 11 '10 at 06:53
  • 5
    This is what it's like when your life feels like a Dilbert comic... – Ivo Flipse Dec 11 '10 at 07:01
  • 50
    Am I stupid for not understanding the moral of the story? :( – Terence Ponce Dec 11 '10 at 07:15
  • 4
    I support @mikeal! Part II! In a way I feel a little bit like Aston.. I've been working for about 3 years, 1 year in my current company.. I'm just saving all my money and thinking of starting one next year :) – Francisco Noriega Dec 11 '10 at 08:16
  • 1
    @Terence: No, you aren't. – KevDog Dec 11 '10 at 08:39
  • 5
    I was expected the last line to read "And he returned to work at the cheese farm with his parent, knee-deep in goat poop, and he lived happily ever after." But it didn't, so where's part II?! – gablin Dec 11 '10 at 09:20
  • 6
    it's not about the story, but how it was told. marvelous. i miss the podcas – Boris Pavlović Dec 11 '10 at 09:38
  • 2
    Love it! Miss the blog, really!! – Nikos Steiakakis Dec 11 '10 at 09:57
  • 39
    Then Ashton said "looked at my kingdom I was finally there, to sit on my throne as the prince of Bel-Air." Sorry couldn't resist. – Jin Dec 11 '10 at 10:06
  • @KristoferA: They all went to San Franscisco :( *grabs the next flight* – Zolomon Dec 11 '10 at 10:20
  • 37
    The moral is if you aren't making a difference in your job or have any opportunities to advance, get a job where you will. I've been in a situation where I knew I was good at my job, but my boss was old fashioned and inflexible and I knew I wouldn't get anywhere, so I left. Best career decision I ever made. – Simon Hibbs Dec 11 '10 at 11:07
  • 11
    Spock would definately win. – Tor Valamo Dec 11 '10 at 12:36
  • 1
    Trollinghorror strikes again. – Incognito Dec 11 '10 at 13:51
  • 149
    The story continues: He went to work for Google, where he worked on Wave. And again, noone was using his code. – Ivo van der Wijk Dec 11 '10 at 13:55
  • 3
    As someone who is from Michigan I resent the portrayal. – Josh K Dec 11 '10 at 16:07
  • 12
    I find the story a bit overstretched and boring, the point made here could have been made very well in 5 or 6 sentences. – Jas Dec 11 '10 at 16:40
  • 6
    @Jas: The same could be said for almost every blog post/short story. But suspense and/or good writing is what adds to the fun :) – Saurabh Sharan Dec 11 '10 at 16:52
  • 13
    @Saurabh - but this is not a blog, this is a Q&A forum, right? – Jas Dec 11 '10 at 16:55
  • Then the story continues even more: he (uh, Lars is is real name, btw) didn't like that Wave was being shutdown, so he went to work at Facebook. – David Murdoch Dec 11 '10 at 17:29
  • 21
    Had I written this, I would been down voted! –  Dec 11 '10 at 19:17
  • @David: Lars is Danish, not Michiganish. – Paul Nathan Dec 11 '10 at 19:21
  • I read your comment twice before noticing you were the CEO of the company. Thank you for letting the guy at the bottom get some sunshine. It really helps. =) – Pablo Dec 11 '10 at 21:22
  • @Jin - A brave, but tragic incursion into the mighty world of comedy. It has been noticed, it truly has. =) – Pablo Dec 11 '10 at 21:25
  • 28
    I don't understand why this has been upvoted so much. Does it even answer the question or is it just a rambling extended story about getting sucked into a corporate grind? – Josh K Dec 11 '10 at 22:35
  • Moral: "And a slave stood behind the conqueror holding a golden crown and whispering in his ear a warning: that all software is fleeting." – David R Tribble Dec 12 '10 at 00:23
  • @Tor Unfortunately, Batman died of shock the moment he looked at Spock, and was never able to fight him. – Mateen Ulhaq Dec 12 '10 at 00:35
  • 2
    I think we could sum up this whole post by a single sentense : "Do something that matters and that people will use" with the implicit complement " and do it well" – Eric Dec 12 '10 at 02:57
  • 21
    We love you Joel, but seeing how this doesn't really answer the question, perhaps this will be a great opportunity for you to earn that "Disciplined" badge! – Macneil Dec 12 '10 at 05:04
  • 1
    Was this actually you or something? – Sudhir Jonathan Dec 12 '10 at 11:47
  • 7
    I believe I will have to explain the answer to my own question. So here it goes: When you try to live up to other people's standards you will always fail to reach them. Only concentrate on being the best you can. Also, if one is eager for success, then one must go to where success can be had. In simple words focus on being yourself, and hustle, because good things only come to those who hustle. – Pablo Dec 12 '10 at 13:51
  • 1
    @Boris "it's not about the story, but how it was told" DAMN you nailed it! – Trufa Dec 12 '10 at 18:14
  • Don't tel me you wrote this ... – Zerotoinfinity Dec 12 '10 at 20:11
  • @Paul Nathan, I was referring to @Ivo van der Wijk's comment, "The story continues: He went to work for Google, where he worked on Wave. And again, noone was using his code." Lars was the brains behind Wave. – David Murdoch Dec 13 '10 at 13:36
  • 7
    I know Ashton. He went to work for Delta airlines as a flight attendant. Eventually, he decided to impulsively quit his job at Delta in an even more dramatic, bridge-burning way than in furniture manufacturer-- he said "XXXX this!" and deployed the inflatable slide on the airplane to make his exit. – Angelo Dec 13 '10 at 18:08
  • @Angelo - mid air? :P – Tor Valamo Dec 17 '10 at 06:48
  • 2
    I must admit I up-voted when I was still only 2/3 of the way done reading, on the assumption that anything with this much buildup must have an awesome punchline. Then I find out it's more like a Peanuts comic, where the punchline is just that it sucks to be Charlie Brown (Ashton). Oh well, +1 anyway, because it is way too effing cold in Michigan. – Tim Goodman Dec 17 '10 at 20:39
  • I bet Ashton milks those damn goats until today! – karlphillip Mar 04 '11 at 00:27
  • Ashton worked at Haworth! – Snowball Sep 02 '12 at 10:04
95

Remember the scene in Aladdin where Aladdin wants to impress Jasmine, and the genie tells him he'd do better to just focus on being himself? Same principle here.

If the boss is that much better than you and you know it, he probably knows it too. He isn't expecting any great feats of programming rock-stardom out of you. Since this is your first job, he most likely hired you because he saw the potential to become a good coder in you. So if you really want to impress him, learn. Learn the language, learn the system you're working on, learn the ins and outs and dark corners. Focus on learning correct principles, learning them well and learning them quickly, in that order.

And remember that part of learning is copying knowledge that other people already have. Don't be afraid to ask questions, either of your coworkers or on StackOverflow, or research things on Google. Whatever you do, don't pretend you know something when you really don't, in an effort to avoid seeming dumb. Any good developer will notice quickly, and that will make you look even stupider in their eyes. Humility tends to still be considered a virtue among engineers.

Do a good job at that and it'll impress the boss.

Mason Wheeler
  • 82,151
  • 24
  • 234
  • 309
  • 2
    +1 and if his boss is better than him - no wonders, here's why: http://www.ericsink.com/Career_Calculus.html – sharptooth Dec 11 '10 at 12:02
  • @Mason : Great and exact answer. But I think you should remove the Aladdin para.... –  Dec 11 '10 at 19:16
  • 3
    Exactly. Even in game programming school I'm one (or the one) who ask questions all the time. But you also have to understand that people don't have always the answer, even a teacher. Several times a teacher answered "i don't know" to me, and I didn't feel proud, but more like "I would better have searched this before wasting this guy's time". Curiosity, just like in sciences, is the BEST VIRTUE you can think to have. Seriously, google any words about some subject you are wondering about. Curiosity is the best learning engine I have, that is the difference between people you call smart and oth – jokoon Dec 12 '10 at 13:20
  • 3
    you know you're in a bad place in life when you're taking cues from a Disney movie. – Epaga Dec 17 '10 at 12:48
46

Two words: Be reliable.

In your position, you weren't hired to be the smartest person on the team. You were hired for the potential you showed and because there are tasks suited for your skill level that need getting done.

Show that you can live up to that trust first, and as you get a feel for the code and the company, find ways to exceed their first impression of you. The latter may take a while, but don't mistake being junior for being inferior.

Joost Schuur
  • 591
  • 4
  • 6
27

What seems like forever ago I took an amazing job working with room full of amazing and accomplished programmers. Everyone was a rockstar, a few people from the original Macintosh team, almost half the people there had published books, it was a great place to be.

So I spent my first year there trying to impress everyone. I felt like I had to do somethign amazing and it drove me to learn more than I ever thought possible in a very short amount of time. In my second year I calmed down, I was a lot more confident in what I was doing, a little more vocal about my opinions, and as I looked around I grew more and more pessimistic about the actual product we were building.

That was the last year that project was fully funded. Those amazing engineers, who I still look up to today, spent 5 years and millions of dollars building framework after framework, an application platform for building on top of an application that hadn't really shipped and finally, a UI and workflow that nobody could understand, even the people that built it.

Smart is overrated. Being a "rockstar" is overrated. It's a really easy excuse to increase your threshold for complexity. It makes you think that it's more important to re-write a working system to be "cleaner" instead of implementing the next thing a customer asked for.

Jacob Kaplan Moss once said something to me about a programmer I won't name, he said "He's too smart. He writes these really smart complicated libraries that I can't use because I'm not smart enough. Stupid people should write libraries so that stupid people can use them".

The programmers that "accomplished" engineers tend to snub their nose at, people that write Ruby and JavaScript and other "toy" languages, those people make PRODUCTS and they SHIP THEM. The code might be ugly, the architecture might not be as pure and clean as you would like, but they ship god dammit and in this industry that's what really matters.

If I were you I'd give up on trying to be this rockstar and focus on shipping and building product. You shouldn't judge your contribution by how clever your code is, you should judge it by how many people run it everyday and are happy.

mikeal
  • 371
  • 2
  • 3
  • 1
    Truth. Write code that is easy to fix when the customers complain, or when something breaks, and you'll look like you have your shit together. – TehShrike Dec 11 '10 at 09:57
  • 14
    Smart is not overrated. If they built an over-complicated and out-of-touch-with-reality system then they weren't smart after all. *Smart* people should write libraries so that stupid people can use them. – EMP Dec 11 '10 at 13:11
  • 1
    I had a similar conversation recently and one of my co-workers described the person code / coding style as 'pretentious'... and I think that really is an apt description... The fellow writing the code is/was brilliant... no one who knew him would disagree... but his code was horribly pretentious... which had the side effect of it being hard to follow for people that weren't similarly brilliant... I like writing code for stupid people (Makes it easier for my dumb *** to understand). – TJ Seabrooks Dec 11 '10 at 13:26
  • 2
    Teams need to be made up of different kinds of people in order to be successful. You need designers, architects, coders, managers, grunts, smart people, detail oriented people, people who care about process, etc. If you only have one type of person your team will probably not work well together and it's more likely to fail than not. Groups that try to hire only rock stars often miss that fact. – onedozenbagels Dec 11 '10 at 13:49
  • @Evgeny Agreed. The point is to make something hard (or at least tedious) easier through abstraction. You just need smart people who love simplicity. – Left For Archive Dec 12 '10 at 09:06
  • This reminds me of the article of Joel Spolsky about "duct tape programmer": http://www.joelonsoftware.com/items/2009/09/23.html – ruslik Dec 13 '10 at 06:51
  • I think some of smart people are delusional. they write something that they think is great, but its no tested(smart people dont need test they can predict everything), sometimes it works weird, because to use it you need to understand how its written and doesnt just work out of the box. – IAdapter Jan 08 '11 at 12:42
  • I think the point is that being smart is good, but being aware of your shortcomings is equally important - particularly if you are smart. If you are smart, it's easy to believe you are smarter thatn others in every way, and that's never the case. – sleske Jul 26 '12 at 06:44
16

Write clear, solid code.

leed25d
  • 1,139
  • 6
  • 6
  • 7
    Including good documentation! –  Dec 11 '10 at 11:44
  • 1
    ...So clear that it's totally transparent. It'll kind of be like hitting an invisible brick wall at 50 mph using a truck. [Who you gonna call? MythBusters!] – Mateen Ulhaq Dec 12 '10 at 00:40
  • Good advice, in general. But unfortunatly it is sysadmin problem - if everything works no one notices you, if something breaks they all blame you. The same is with the code: if it is clear, simple and just works then no one would believe that it was hard to write it. So it is not the way to be "recognized". –  Dec 28 '10 at 07:30
  • 1
    try to be replaceable - this way you will get promoted or replaced. – IAdapter Jan 08 '11 at 12:46
  • lol @try to be replaceable! Don't you mean be irreplaceable, by writing replaceable code? – Anonymous Type Jan 17 '11 at 02:40
15

Knock on his door. Ask him if he has any shit jobs he's been putting off that you might be able to handle. Tell him to just fire you off an email later if he doesn't have time right now.

SnoopDougieDoug
  • 548
  • 2
  • 3
13

Read Knuth

(corollary: many people have Knuth, but no one reads Knuth)

All the really good programmers I've worked with have some traits in common:

(1) Even though you don't have to be good at maths to do programming, they were anyway (and they liked it)

(2) They appreciate a quality I will call 'elegance' - not to be confused with brevity (!!!)

(3) They are good at designing software (even if none of us can explain what good design actually is)

In addition, I personally find the following traits handy:

(a) enjoying solving puzzles

(b) writing readable code

(c) a good memory

(d) can superficially adapt to other programming languages easily (breadth)

(e) learn your main language in depth (e.g. do the Java certification if Java is your environment (for clueless detractors that never did this but slag off certification since Microsoft's certification is (was?) really bad ... the benefit is not in having the piece of paper, the benefit is in the study))

(f) given the choice of doing something simple and easy and then moving on, or something super complicated that will take weeks/months, I do the simple thing. I like simple, since it tends towards robustness, also it is more flexible when requirements change in mid stride, and is a lot easier to communicate to other team members

(g) if you do something you consider especially cunning, document the smeg out of it

Someone (Djikstra?) said that debugging is twice as hard as coding, therefore if you write code that is at the limits of your ability, you are by definition not smart enough to debug it.

========

Having said that, becoming a smart/better coder is not the same as advancing your career.

There is really only one 'secret ingredient' required for advancing your career, and it is people skills.

If you really want to progress your career, the best thing to do is to quit, and go sell cars for 6-12 months.

Rick
  • 131
  • 2
  • 3
    That quote I think is Kernighan: http://stackoverflow.com/questions/1103299/help-me-understand-this-brian-kernighan-quote – Orbling Dec 11 '10 at 14:40
  • 2
    “Debugging is twice as hard as writing the code in the first place. Therefore, if you write the code as cleverly as possible, you are, by definition, not smart enough to debug it.” - Brian Kernighan – Ape-inago Dec 12 '10 at 07:38
  • 4
    On good memory: I knew a very good programmer with extremely good memory. He could look at the code he wrote 2 years ago and remember what he was thinking at the time. Hence, he never put much effort into writing good comments - just enough keywords to create a hash code. My memory sucks. I HAVE to comment things well because I know that 1-2 months after I filed a bug, I would have to do the same as someone completely new - e.g. read every freaking step of it. Of course, some things are more vivid that others ... I am not saying that I am a great, but maintainers and testers tend to like me.;) – Job Dec 12 '10 at 15:33
  • 1
    Elegance and brevity have a lot in common, nonetheless. –  Dec 28 '10 at 07:34
  • I met a lot of great programmers and I never notice they even know what math is, why? you only talk about math at school and bad programming interviews. unless you talk about premature optimization, i met people with amazing adding skills(they even could add things that exist only in their heads, i think its called discrete math). – IAdapter Jan 08 '11 at 12:58
11

I hv been coding for over 20 years, and currently have 10 programmers working with me. I have to say that those impresses me are those that did their job well, deliver on time and with quality (less bug). communicate frequently, showing passion are all important factors.

thats about it i can share right now. ;)

wsatp
  • 111
  • 2
  • Do you have any shitty jobs to do?(as mentioned by Doug in answer-25473) because I think there are none, but I could be wrong. – IAdapter Jan 08 '11 at 12:49
9

Well, I just would add this quote from gospel:

"Whoever can be trusted with very little can also be trusted with much, and whoever is dishonest with very little will also be dishonest with much."

  • 3
    That is from [Luke 16:10](http://bible.cc/luke/16-10.htm) : "He who is faithful in the least is also faithful in much; and he who is unrighteous in the least is unrighteous also in much." Also: "Well done, good and faithful slave. You were faithful over a few things; I will set you over many things. Enter into the joy of your master." (Matthew 25:21) – Mark C Jan 26 '11 at 05:05
7

Having been a boss to programmers, I can tell you that nothing made me happier than when a programmer fixed a bug that I was to lazy to go fix!

So if you can, fix his bugs for him.

Lone Coder
  • 171
  • 4
6

As Steven says, Mason is right -- focus on your own game. The thing to bear in mind is that your boss just wants you to do your own job well. He probably actually likes the fact that he's better than you -- if he wasn't, he might well end up feeling insecure (bosses are human!). Right now, you're in an ideal position to learn from his experience -- don't waste time competing with him, ask his advice on things instead. If you've ever read the 48 Laws of Power, the key one is "Never outshine the master".

6

Solve Rubik's cube. The boss will know that you like challenging puzzles and will give you tough assignments.

Manoj R
  • 4,076
  • 22
  • 30
6

If you want to make an impression on your boss, be honest. At your weekly 1-1, ask him what is most important for you to focus on, and do that. Try to understand what he thinks your role is, and do your best to fulfill it. It is possible that he needs you to do certain tasks so he can concentrate on the stuff he is doing. If you try hard to do the things he is doing, you might not be doing enough of your own task. Find your spot on the team, excel at that, and then expand. Tell him that you want to help out.

akf
  • 161
  • 2
  • 5
5

@Mason is right

  • listen
  • learn
  • ask relevant questions at respectful intervals (e.g. twice a day, not every 5 minutes)
  • relax and be yourself
Steven A. Lowe
  • 33,808
  • 2
  • 84
  • 151
5

To my notion, the biggest asset a green programmer can bring to the table, beyond his existing technical skills, is initiative and passion. If you show your boss that you are aggressive about learning new things, aggressive about learning your way around the company, the code-base, the tools, and your co-workers, and you show that you have a passion for what you are doing, that will impress. Unless you're working for a horrible manager, in which case you want out anyway.

I would also suggest putting some focus on "soft skills" stuff. Demonstrate that you aren't just a geek who is useless in any sort of inter-personal interaction. Make friends with the people in sales, marketing, support, business development, project management, etc. Show that you are a good communicator and somebody who can work with people to get things done.

mindcrime
  • 520
  • 4
  • 6
  • Sh.t accumulates in the code base over time, and usually the green folks notice it the most. Sometimes reading it for the first time can make one queasy. Depends on how large organization is, on how well they score on Joel's test, etc. – Job Dec 12 '10 at 15:44
3

If you have the freedom to do so: Write grants, bring in some grant money from outside, or start a cooperation that has business value, with new partners that consider you a competent programmer or -at least- valueable employee.

knb
  • 747
  • 1
  • 8
  • 16
3

Don't bother with impressing people or your bosses. Nobody is impressed by just talk. Concentrate instead on shipping code. Ensure you are involved in projects or applications that will be used by people. More code you have in production more relevant you will be. More relevant you are to people more they will rely on you. Rest is all magic show.

user9631
  • 31
  • 1
  • 3
  • good point, you should become Release Manager and don't let other people tell you what to write, write what you want and ship it! – IAdapter Jan 08 '11 at 13:11
2

Work hard. Do everything you're told and learn everything. You're very lucky to work under someone who knows a lot more than you, keep working until you can catch up.

In addition to working hard, and succeeding in the job you're in now, I'd like to give some advice that is maybe an answer to the question you're not asking. (It wasn't even on my radar when I got my first software job).

The internet is made by people like you. And people like you can make money on the internet.

Find something you're passionate about. Build it. Sell it. Be your own boss.

  • Open up http://news.ycombinator.com and start reading the articles. You're going to see an endless wave of stories from people like you, who had an idea, built a website and managed to make a dollar or two doing it. It's inspiring and eye-opening there's a guy who earns a ridiculously good wage selling a bingo card generator to teachers... another guy who sold a website to google for millions. There's a lot of other interesting technology stuff in there too.

  • 'Rich Dad, Poor Dad' there are places where he's got good advice.

  • 'The Four Hour Work Week' take this one with a grain of salt, but he does have some interesting ways of looking at work & life.

Keep learning from the guy you're under now. There is so much to learn in 'your first real job' that I can't even begin. In the long run though (three, five, ten, twenty years) if you learn how to make your own money, you won't have to worry about impressing someone else.

Alex C
  • 189
  • 7
2

You can rarely impress people by trying to impress them. And as long as you try to impress people, and they don't seem impressed, your frustration will grow.

Just do your job in a way that makes you proud of yourself. Don't worry about what anyone thinks. The only person you can make happy is you.

Kristopher Johnson
  • 1,719
  • 4
  • 15
  • 15
1

I liked the story posted in the answer, but it's more entertaining than a reliable answer.

It's normal that everyone are just like you: trying to be better at what we do, that's human. But the horrible truth is that there are so little chances you will be the best at it.

Concerning myself, I always feared humility concerns, because I just hate those little childish fights about who's right and who's not, and here is why.

As long as you are not one of the best, you are better trying to work to get more experience comparing what you know and do to what best programmers know and do.

You could say I compare myself to the best programmers, but that's just half right: - I'm better comparing myself to the best, knowing that I'm just ridiculous compared to them, so that makes the principle of comparing pretty stupid and useless - I don't consider their fame but rather what they achieved to get it, because in reality, most geniuses myths fade away when you know true fact like how business works. It doesn't change the fact they achieved great work, but remember that experience is difficult to evaluate if you think about the working conditions. - In the end, this process avoids the competition process which is really disturbing for me and help me focusing on what is important: learning by practice, but also learning with the help of a good curiosity engine.

You can admire somebody all you want, thinking he is so better than all other employees or other programmers you'll meet, but you have to remember that the world is vast and that the guy you admire is in fact quite average compared to other better experienced people there are out there, so maybe you'll feel better once you've impressed him, but you'll feel the same against other people with better experience than him, so it will be all for nothing.

Quit this petty game and try to find more interesting subjects you might have heard about, because this engineer you are talking about is certainly busy working for something less great that you're thinking.

jokoon
  • 2,262
  • 3
  • 19
  • 27
  • Thanks to this post, I was able to understand that. When you are coming down from the very bottom, heroes are tools that I used to keep me motivated. But, now that I've reached a better place, I have to become my own hero and work hard. Not for recognition, but for myself. My father, who is a wise man, once told me that the secret to success was me. I never did get that one up to yesterday. Thank you. – Pablo Dec 12 '10 at 14:04
1

I have to agree with some of the others here in that you are likely to fail in your objective -- because you are focusing on the wrong problem, or at least your focus is too narrow.

You want to be a great programmer -- does the subjective opinion of one software engineer bestow that title and ability on you (other than Joel)? If you focus only on impressing your boss then you are not concentrating on the work, or on improving your skills -- you are not focused on your goal of becoming a great programmer. You are trying to be granted respect rather than earning it.

Let's take the worst case (because programmers like to do that) -- your boss absolutely hates you for no objective reason (you wore a Patriots hat the first day, whatever). He's just never going to have a good opinion of you. If you concentrate on completing your tasks assigned, on solving problems efficiently and elegantly, and furthering your technical skill set -- you will improve yourself -- then in the end you are the winner -- independent of what your boss thinks.

Ashton job was a recipe for failure not because his code went unused, but because the job provided him with no practical benefit other than safety on Maslow's hierarchy. Was he learning new skills? No. Did his work allow him to be creative? No. Did it earn him respect? No.

Being that this is your first position, it will offer you most of these properties by default. You will have your first experiences programming professionally, you will be given new challenges both technical and non-technical. But there will come a time when you outgrow the position or it outgrows you, and you need to be continually improving yourself so you're not caught off-guard by it.

One more thing, if Ashton's going to measure his self worth merely by the amount of people using his code then I suggest he join a frequent-flier club. The only lasting happiness in life is that which we create for ourselves. Living strictly according to what other people's opinions of us are produces tragic and inauthentic human beings.

Watson
  • 2,262
  • 14
  • 16