How to Invest in Engineers' Growth πͺ΄
Real-world strategies, programs, and ideas, to enable continuous professional development at work.
Professional development for engineers has been a big interest of mine for a long time.
This dates back to the first years of my startup, around ~2012, when we had to hire our first engineers. The tech ecosystem in Rome is small-ish and it was hard for us to find devs who had any experience in our stack (Ruby on Rails).
So, since both myself and Disheng, one of my co-founders, were PhD students, we leveraged our university connections to create internships and hire people straight out of their Bachelors or Masters. Then, during their first months we would teach them everything about the tech.
Now, this use case was quite specific and born out of necessity but, in general, investing in the professional growth of engineers is a total no brainer for any tech company.
In fact, it brings benefits across the board:
πΌ Hiring β it makes hiring easier, cheaper and faster, by lowering the bar of the experience you need to hire for.
π Turnover β it reduces turnover, by creating growth opportunities for engineers.
πββοΈ Productivity β it obviously increases productivity, by improving engineersβ skills.
It also turns out professional growth is what engineers value the most. A while back we ran a wide survey about engineering careers, and asked hundreds of managers and developers why they had changed jobs in the past. Growth is #1 π
Still, creating a good process for this is hard. You canβt just slap an OβReilly subscription on your team and call it a day.
So, this piece collects the best ideas from some of the smartest people I know, plus learnings from my experience, and insights backed by research.
Here is what we will cover:
π Passive vs Interactive β ranking learning experiences by effectiveness.
βοΈ Exploratory vs targeted β the two goals of learning.
πΌ Learning at work β real-world programs, tactics, and workflows to help your engineers grow.
π Special deal for paid subscribers β for an upcoming Refactoring product for teams.
Letβs dive in π
π ICAP framework
The ICAP framework was created in 2014 by Michelene Chi, who demonstrated how higher student engagement leads to a better learning outcome.
ICAP buckets learning experiences into four main categories, in ascending order of engagement, and, therefore, effectiveness:
π΄ Passive β experiences where you are just exposed to some learning material, like a book, or a lecture.
π‘ Active β experiences where you have exercises to complete as part of your learning like regular online courses.
π’ Constructive β experiences where you learn by doing. Building is a core part of the learning process, like in a workshop.
π£ Interactive β experiences where constructive learning is augmented by asking questions and getting continuous, real-time feedback, like in pair programming.
Interactive learning leads to the highest retention, especially in areas that are very hands-on, like tech skills.
You can put popular education options on this scale, from the most passive to the most engaging: books, newsletters, online courses, workshops, 1:1 coaching, pair programming, etc.
When it comes to the quality of learning, there is no doubt that the more you move to the right, the better.
However, deep interactive experiences are not always the best call. In fact, these are also:
Hard to design β itβs tough to create learning material that includes a lot of building and active stuff, as opposed to simple slides or text.
Hard to scale / expensive β the more feedback loop people need, the more bespoke the experience needs to be, the worse it scales. Some of the most interactive learning experiences in tech are pair programming and coaching, which are both 1:1.
Demanding for the learner β interactivity is about intensity. You are getting more results because you are putting it more effort. You canβt always afford that.
So, passive experiences may have low retention but are also cheaper and low-effort. Sometimes, thatβs bad β but sometimes thatβs just what you need.
E.g. I am a fan of the RealLifeLore Youtube channel to learn more about geopolitics. I donβt have a personal goal about this, so I am just happy to watch some videos, knowing that my understanding will be shallow, and retention low. Also, I usually watch them over lunch, so I donβt really have the energy bandwidth for more. For this use case, the passive approach is perfect!
So, I believe you can maximize learning by finding the right blend of passive and active experiences, based on what you need the learning for. Letβs see how to use this for work π
βοΈ Exploratory vs Targeted learning
As a basic mental model, I have found it useful to organize learning experiences into two broad categories, based on your goals about them:
π Exploratory β this is serendipitous learning. You learn stuff for the sake of it, driven by your curiosity.
π― Targeted β this is learning that is driven by some goal. You learn something because e.g. you need to perform a certain task.
As it is often the case, this is more of a spectrum than a black/white separation:
The geopolitics videos I watch over lunch are 100% exploratory.
The React Native workshops I attended years ago when we had to create our mobile app were 100% targeted.
Me looking into Astro because it looks cool and might turn out useful one day is⦠kind of in between.
There is a balance to be found between the two, that, to me, looks like ~80% targeted and 20% exploratory.
In fact, I believe most learning should be directed to specific goals. Thatβs how you are the most effective and how you should spend the most of your learning coins. However, you also want to keep some slack and encourage casual, serendipitous learning in your life and that of your teammates.
This is similar to the recommendation algorithm of Spotify β actually, I donβt know, I have no idea how it works β but I would like it to 1) 80% double down on things that I like, and 2) 20% make me discover random stuff that is different from what I listen, so I donβt corner myself into the same things over and over.
As for learning modes, you want to invest in interactive experiences for targeted learning, while it is ok to go for passive, more laid back ones for exploratory stuff.
So, you wouldnβt do pair programming for learning some new exotic tech that may or may not be useful in the future. At the same time, if you have a pressing problem, reading a book isnβt probably your first choice β you may rather get personalized help by talking with a peer, or a coach.
So, how do you create such experiences at work? π