As a technical co-founder, the second most-asked question I receive (behind â€œwhere do I find a technical co-founderâ€) is from engineers asking me, â€œWhat language/framework/ new-hip-thing should I learn?â€
This question has always puzzled me, especially when it comes from seasoned veterans who have well-respected jobs. Although my alma mater taught me this way as well, this is not the way I think â€” and neither should veteran engineers. Why would you want to learn yet another language, when that language is nothing more than a set of instructions that tell a machine how to behave? Any engineer worth his salt can pick up a new language in a matter of weeks. The same goes for a new framework. If youâ€™ve been writing software for 10 years and youâ€™re worried about the new hot framework out in the world, youâ€™ve lost the forest for the trees.
The bigger question is, how do you take your knowledge of language and software systems to hack real-world systems? I look at this as a form of social engineering; instead of the goal being to teach a machine how to behave, you are attempting to create a machine that mimics the way humans behave. Or better yet, teach the machine to behave the way the user expects it to behave.
This is the difference between a good product and a great one, and it has nothing to do with software. Companies like Twitter had to change the way humans behaved. It was a long and arduous road, and people still donâ€™t â€˜get Twitter,â€™ whereas companies like Apple and Facebook have painstakingly studied human beings and purposely built products around their needs.
I canâ€™t tell you the amount of times that Iâ€™ve come into an engineering meeting where one engineer is bragging to another that in five lines of beautifully succinct code they have been able to complete their task in record time with flawless execution. But I can count on one hand the number of times an engineer has bragged that they changed five lines of HTML and upped the engagement rate 10% on a feature that everyone perceived as useless. A hack is a hack, and thatâ€™s what engineers do. I donâ€™t care if it took zero lines of code or a hundred and a roll of duct tape to complete the task, and guess what? Neither do your customers. The product is all that matters.
Both Facebook and Apple have taken this to extremes by hacking human perception. Facebook recently discovered that by changing their loading animation icon to what iOS and Android natively do, the user couldnâ€™t tell if the slowness was coming from their phone, their carrier, or Facebook itself. This simple, genius hack saved so many man hours and millions of dollars of server time itâ€™s hard to even quantify the impact. Apple has done something similar by creating a stripped progress bar that scrolls at just the right speed so you feel as though it is moving faster than it actually is.
These hackers were so perceptive and audacious that rather than engineer a faster application, they decided it was easier to change the usersâ€™ perception of time. All of this by changing very little code and no infrastructure.
Next time youâ€™re hiring an engineer, donâ€™t just ask them the usual whiteboard questions and what they learned in college 10 years ago. Your job is to find out if they are willing and able to program the way users behave â€” or just program computers.
June 25, 2014