I stumbled upon a recent and very interesting blog post from Rick Strahl: "The Search Engine Developer". Rick in turn was motivated by a post from Scott Hanselman who asked "Am I really a developer or just a good googler?".
That inspired me to write this post, too. Mostly because this topic has to do a lot with self-improvement, learning and attitude.
What is it, what Ninja calls Googlevelopment?
We all know it: If we encounter something in our job we don't know, it is very tempting to throw some words related to it into the search engine of your choice, sift through the results and if there's a link to StackOverflow or to a blog from certain persons you know (like from conferences, book authors, via twitter, from others that pointed you to them earlier), these are your first stops. You don't even look further, because your problem is most probably solved. You copy the code, paste it into your solution, make some adjustments, test it and don't think further. There's no problem anymore.
the a point
Scott is just having so much keystrokes left, and because of that didn't give a broad explanation on WHY he has the opinion he wrote down. Well, it isn't even in fact an opinion you read in his post, but a call for action: Try to stop googlevelopment and do it the old fashioned way: Write it yourself, go to user groups, learn, do code Katas etc. One can easily guess that Scott thinks googlevelopment is a bad
Hobbit habit, and you shouldn't do it.
Rick, instead, was a bit more chatty. He mentioned that it "feels like [he's] become a slacker at best and a plagiarizer at worst" sometimes. He summed up his experience, back to the days where there simply was no publicly available Internet - no chance to copy your code -, through the 90ies (some online manuals, discussion forums), through the millenium where blogs started to spread and up to now, where collaborative sites like StackExchange are flourishing.
Using libraries, for Rick, is "standing on the shoulder of giants", and copying and adopting code from the intertubes gives him a rough feeling about the interior of the library, to be able to use it the right way, but not too deeply because, his example was a QR code library, that's not his actual problem domain.
He, while being totally right on that matter, said that there is no need to re-invent the wheels others invented previously. And then, there's this bummer: "It's fun to wax nostalgic about 'back in the day' stories, but I don't miss those days one bit. I don't think anybody does..."
Not missing the old days?
Rick, honestly? You don't miss these days? I think this 'back in the day' time was the time that made you the developer you are today. Those were the days that made you learn your stuff.
Today's younger developers, that didn't went through this (more or less hard) school of learning by themselves, trying things, failing, learning from their failure, inspecting stuff, who JUST started as 'search engine developers' or googlevelopers, can't really leverage the information they find on the net. Fiddling around with your platform, with your compiler, with sample sources (if any), with documentation is in the first place teaching you how to learn.
Rick then goes on describing that, because there are so much things out there, it could happen that you have a great idea and want to go on this. Then you might find finished implementations (even if not really 'good') - and just stick with them. Even if those implementations would deserve a new competing library from exactly you - because you could do better. But you left it alone.
Making this decision, re-implement or stick with a not-so-good solutions, is, of course, mainly driven by time / effort / money, but also by an educated analysis of risks and chances and the technical debt you're taking when using a not-so-good solution. You also need to be educated to estimate whether a re-invention would benefit your (and maybe others too, talking about open source) solution.
You can't, however, get that evaluation right when you haven't learned the implications of doing it yourself vs. using existing stuff when you did not do a lot by yourself previously.
Ask a Ninja: Is Googlevelopment bad?
So, now it's time for my personal opinion on that topic.
I already mentioned that I'm not with Ricks point of view. I think it's sad that he does not miss the old days. I started developing software very early. I got my first PC when I was 9 and two to three years later just 'using' it got boring. With 14 I wrote the first program that I sold to a doctor to manage lists of his patients. The german health insurance card was just available and there were keyboards with an integrated card reader that would just 'type' in all the data from the card when it was inserted.
My program just stored the data in a flat file (I didn't know that this format I chose was already known as CSV), and I had to invent and implement my own sorting algorithm. If I remember correctly, I did something like an insertion sort. I figured out ways to send that data to a printer when requested. And I spend a lot of time formatting the outputs of my program to look nice and present them in a beautiful way to its users (mostly young women that worked there and that I tried to impress back then, hell I was 14 🙂 ). So, I figured all that out. It took long. I learned a lot. And it was fun.
I'd love to learn new stuff all day. Fiddling with stuff. Trying to get things done by myself. I really miss that a lot. Sadly, in todays businesses this isn't possible anymore. There's just a tiny window of time available for that kind of stuff.
Finally Rick comes to this conclusion: "Search engines are another powerful tool in our arsenal and we can and should let them help us do our job and make that job easier. But at the same time we shouldn't let them lull us into a false sense of security - into a sense of thinking that all we need is information at our fingertips.".
Having all that information at our fingertips empowers us to build great stuff. It is information we can use to learn from it. And we have the power to decide to NOT use it. Rick linked to an older article from Scott: We need to Sharpen the Saw - this is us - on a regular base.
We should try to develop - not googlevelop - more stuff by ourself. This strengthens our skills and makes us more sensitive for when we have to use stuff others did. We need to find the right balance between "standing on the shoulder of giants" and trying to be the giant. This fine line, where you're in balance, is a moving target, though:
- Young Padawan, more fiddling on your own, not using the force you must.
- Knight, use the force and learn from it.
- Master Jedi, more fiddling on your own again you should.
This is my idea. Well, not really mine. I just adopted it. With some friends I share a maxime. In German: "Schau in Dich. Schau um Dich. Schau über Dich." This goes for three steps of learning:
- "Schau in Dich." - Look inside you. This is about self-awareness. You should learn about yourself, about your learning.
- "Schau um Dich." Look around you. This is about learning not from yourself, but from others. And also about learning what your influence is on others, but that would go to far at this stage.
- "Schau über Dich." Look beyond you. Okay, that is a very loose translation. The aim of this part is to make you think about things in a larger scale, and push the limits.
This is also, what the learning of an apprentice, journeman and master craftsman was back in the old days. The apprentice should learn to learn. The journeman travels around, this enables him to learn more from others of his craft. The master then knows the basics of his craft, but he also tried to improve his skills, to be able to compete. Masters also could leverage their skills to try our really new stuff on their own - and succeed with that. Masters usually also were eligible to join the guild, where there was a lot of exchange between them - also about new stuff they discovered.
There is a slight chance, that this, what was done for decades back then, had some truth in it. And we software developers, engineers or craftsmen, could (and should) try to map this to our daily learning again.
Well. This is just a line. At the bottom. For no reason. 🙂