data:image/s3,"s3://crabby-images/6821e/6821e8d8e4d2e20f7a20362661d4988065c4e637" alt="Want cleaner code? Use the rule of six"
Everyone wants to write clean code. There are whole books about it!
But you don&apost need to read a book to write cleaner code right now. There&aposs one "trick" that every coder can learn to make their code less confusing.
The key is:
Every line does only one thing
One line, one task.
But don&apost go crazy with it.
data:image/s3,"s3://crabby-images/cb959/cb959f70a04fc8c0714c4076a5ab0042e2fd9dbd" alt="Want cleaner code? Use the rule of six"
Here&aposs the main idea: Short lines of code require less brainpower to read than long ones. Code that&aposs easy to read is easier to reason about. Programs with shorter lines are, in theory, easier to maintain.
But compact code can be cryptic. (Ever seen APL?) And just because you can split a line doesn&apost mean you should.
In some languages, you can assign two values to two variables on one line:
x, y = 2, 7
You could put both assignments on their own line:
x = 2
y = 7
But, c&aposmon. Do you really need to? How can you tell if a line should be split up?
It&aposs not all about line length
Felienne Herman opens her book The Programmer&aposs Brain with an undeniable truth: "Confusion is a part of programming."
data:image/s3,"s3://crabby-images/d242a/d242aa130da39c894dcd9dbc74a488d52f66db8e" alt="Want cleaner code? Use the rule of six"
Herman&aposs book (which I highly recommend) explains how your brain&aposs three memory functions work together to understand code:
- Long-term memory (LTM): Stores information for long-term retrieval, such as keywords, syntax, and commonly used idioms and patterns.
- Short-term memory (STM): Stores new information for short-term retrieval (less than 30 seconds!), such as variable names and special values.
- Working memory (WM): Processes information from LTM and STM to draw conclusions and derive new knowledge.
STM and WM are small. Both can only store about 4 to 6 things at a time! Overload them and you&aposve got a recipe for confusion.
data:image/s3,"s3://crabby-images/cc6dd/cc6dd70fc31cb9c79ede65f14eea77efc3a5c3a7" alt="Want cleaner code? Use the rule of six"
That gives us a rule for deciding if a line of code is too complex:
A line of code containing 6+ pieces of information should be simplified.
I call it the "rule of six."
Here&aposs an example in Python:
map(lambda x: x.split(&apos=&apos)[1], s.split(&apos?&apos)[1].split(&apos&&apos)[-3:])
Is that hard for you to read? Me too. There&aposs a good reason why.
You have to know what map
, lambda
, and .split()
are. The variables x
and s
, the strings &apos=&apos
, &apos?&apos
, and &apos&&apos
, the index [1]
, and the slice [-3:]
all take up space in STM and WM. In total: ten things! Your brain can&apost keep up.
Or maybe yours can.
If so, you&aposve got some good experience under your belt.
Your brain "chunks" syntax like s.split(&apos?&apos)[1]
into "the part of the string to the right of the question mark." And you can reconstruct the code using information stored in your LTM. But you still only process a few chunks at a time.
So… we can identify when a line of code is too complex. Now what?
Want more like this?
One email, every Saturday, with one actionable tip.
Always less than 5 minutes of your time.
If code is confusing, break it
Break it into smaller pieces, that is!
There are two strategies I use to break up code. I call them SIMPLE and MORF.
The SIMPLE strategyadds lines of code to decrease cognitive load.
data:image/s3,"s3://crabby-images/a5503/a55035e63a925a4af2b558908d95e8b18312076d" alt="Want cleaner code? Use the rule of six"
Let&aposs apply SIMPLE to that nasty one-liner we saw earlier. Remove the second argument from map()
and put it on its own line:
query_params = s.split(&apos?&apos)[1].split(&apos&&apos)[-3:]
map(lambda x: x.split(&apos=&apos)[1], query_params)
It still might be hard to read. There are seven things to keep track of in the first line:
query_params
s
.split()
&apos?&apos
[1]
&apos&&apos
[-3:]
But each line has fewer things to track than before. Your brain can process them more easily.
Apply SIMPLE again and move s.split(&apos?&apos)[1]
to a new line:
url_query_string = s.split(&apos?&apos)[1]
query_params = url_query_string.split(&apos&&apos)[-3:]
map(lambda x: x.split(&apos=&apos)[1], query_params)
Compare that to the original one-liner. Which one is easier to process?
The MORF strategy takes a different approach and groups code into functions.
data:image/s3,"s3://crabby-images/251eb/251eb625ade687509c94210b4bfd78f876390a01" alt="Want cleaner code? Use the rule of six"
Here&aposs what MORF looks like applied to our one-liner:
def query_params(url):
return url.split(&apos?&apos)[1].split(&apos&&apos)[-3:]
map(lambda x: x.split(&apos=&apos)[1], query_params(s))
You can even combine MORF and SIMPLE:
def query_params(url):
query_string = url.split(&apos?&apos)[1]
return query_string.slit(&apos&&apos)[-3:]
map(lambda x: x.split(&apos=&apos)[1], query_params(s))
You don&apost have to understand the code to feel the effect. Each line is easier for your brain to process.
There&aposs a bonus benefit, too!
Once you know that your WM and STM aren&apost overloaded, you know that any confusion left over is due to missing information in your LTM.
In other words, SIMPLE and MORF don&apost just help you write cleaner code. They help you identify knowledge gaps that you can improve with practice!
Want to know more about how your brain works while you&aposre coding?
Check out The Programmer&aposs Brain by Felienne Herman.
Get instant access through Manning, or order it from Amazon.
data:image/s3,"s3://crabby-images/cea46/cea4604d2627e295568375d02fde2b74ab72b53d" alt="Want cleaner code? Use the rule of six"
Exercise
Look at the code we ended up with using SIMPLE:
url_query_string = s.split(&apos?&apos)[1]
query_params = url_query_string.split(&apos&&apos)[-3:]
map(lambda x: x.split(&apos=&apos)[1], query_params)
One line still has over six "ideas" in it and should, according to the rule of six, be split up:
- Which line?
- What are the "ideas?"
- How would you split it up?
- Did splitting it up make a big difference?