From the perspective of an individual, increasing productivity comes down to a few things:
- Increasing Focus (reducing multitasking, reducing interruption);
- Frequent Customer Feedback;
- Reducing Friction.
Multitasking feels more responsive and is guaranteed to slow completion times
Let’s say you get 4 requests.
data:image/s3,"s3://crabby-images/8d82e/8d82e7347adc69fff19967957ebfd9e08336168a" alt=""
In order to appear responsive, you work on all of them at the same time. In reality, given it’s just you working on them, you’re not actually working on all of them at the same time so much as switching between them.
In the end, every requester will feel like you responded to their requests and, assuming similar sized requests, all of the work is completed at roughly the same time at the end.
data:image/s3,"s3://crabby-images/22008/2200817ebdacd6b62edb953fe9bfab92ce8ac5be" alt=""
Alternatively, if instead you focus on completing one request at a time, every request except the last one is completed significantly sooner.
data:image/s3,"s3://crabby-images/23556/2355697df8dbf38d0e09ec938a04243d38ed79d0" alt="Multitasking sequence showing ABCD representing 4 different projects. Each projects finishes near the end. “One request at a time” sequence shows AAAABBBBCCCCDDDD with each project finishing much earlier except for D which finishes at the same time."
ASIDE: In practice, a single request might not take up all your time
Sometimes, when working on a single request, you’re waiting on a machine, a process, a dependency, etc. So you might use the down time to work on a second request, general improvements, learning, etc.
data:image/s3,"s3://crabby-images/b74d3/b74d332a7d51833cfc3898f71a86c69fcae477cf" alt=""
The cost of context-switching makes multitasking even worse
Context-switching has a mental cost to humans and it makes the cost of multi-tasking even worse. This means the last item when single tasking might complete before even the first item is complete when multi-tasking.
data:image/s3,"s3://crabby-images/8f5a7/8f5a730e647d626cf0bde9327151d29f8582483f" alt=""
See also The Multitasking Myth (codinghorror.com) which includes a chart by Jerry Weinberg proposing some heuristics on the cost of context-switching as the number of simultaneous projects increase.
data:image/s3,"s3://crabby-images/939d2/939d261f5c2275b8279bd7ff5419ed11eb72f5d4" alt=""
Context-switching also applies to interruptions
The cost of context-switching applies not just to switching between requests but also applies to all forms of interruption, for example meetings.
data:image/s3,"s3://crabby-images/e22c4/e22c4faced02489d25563b79708cd9d4a97a5489" alt=""
Not every part of a request has the same level of priority
What if you broke up the 4 requests and prioritised the smaller parts? It may not be the case that every part of a request has the same importance. You may want to do this breakdown and sequence them to optimise the completion times of the different parts.
data:image/s3,"s3://crabby-images/01abf/01abf9dbec369233510515146a607d1819b42b37" alt=""
Without feedback, building the wrong thing feels productive
When do you want to know that what you’re building is wrong?
data:image/s3,"s3://crabby-images/0016e/0016ecdd5456c9fc919b6ee4b649267a7a9c1876" alt="One approach where the person is not interrupted but realises late that they built the thing wrong and needs to fix it. Another approach where the person is interrupted to get early feedback, realises they are building the wrong thing earlier, and fixes and finishes earlier."
An interruption that helps you detect that you’re building the wrong thing is generally a useful cost.
Friction is everything around a task that makes it difficult to complete
Any variant of “I spend 10% of my time productively working and 90% of my time fighting with X” is an expression of friction.
Friction is how I describe what happens when your attempts at progressing a task is hampered due to tooling, environment, the technology you’re using, lack of knowledge and the ability to acquire it, etc.
data:image/s3,"s3://crabby-images/bd9bc/bd9bc2f9f210d0eeec84b6a1566374334b914d40" alt=""
Multi-tasking and lacking feedback generally have significantly larger impacts on productivity than friction but if you’ve addressed multitasking and feedback already, reducing friction can still provide noticeable improvements over time.
See also
- DevEx: What Actually Drives Productivity — ACM Queue which identifies 3 core dimensions of Developer Experience (aka individual productivity): feedback loops, cognitive load, flow state.
- Team productivity (not the same as individual productivity)
- Organisational productivity (not the same as either individual or team productivity)