Things senior
developers should know
@hanokhaloni
Hanokhaloni
hanokhaloni
What should junior developers
learn?
The job is not to
write code
What is the job of a bus driver?
(Yes, this is a trick question)
Our job is to write code to amplify
business value
Functional requirements
Non-functional requirements
Security of investment
We are building a business asset
You’re paid to think
It’s not about being a code
monkey churning out working
code
It’s about critical thinking,
prioritization and strategy
Often the first step is discover the
real problem
Strong opinions, weakly held
Software
development is a
team sport
Interesting problems are too big to
tackle solo
Diversity of viewpoint is essential
for success
Not everyone on the team will be
technical
Effective communication is
therefore an essential skill
You can’t specialize in everything
What should junior developers
learn?
You don’t live in a box
No matter how
careful you are,
you will make
mistakes
Coding conventions help us avoid
common mistakes
Code reviews help us find mistakes
Static code analysis tools detect
potential mistakes
Source code control helps us
recover from mistakes
Automated testing prevents
mistakes
Continuous Integration alerts us to
mistakes early
Continuous Deployment helps us
fix mistakes quickly
The impossible
happens
One in a million events happen
every Tuesday
Leave a good looking corpse
You have to cater for change
How to answer
“How long?”
The difference between a
prediction, a target, and a
commitment
A prediction is based on
everything you already know
A target is when you’d like to finish
A commitment is what other
people use in their plans
If your target is later than your
prediction, you’re conservative
If your target is later than your
prediction, you’re conservative
Prediction
Target
If your commitment is later than
your target, you have room to
move
If your commitment is later than
your target, you have room to
move
Commit
Target
If your target is earlier than your
prediction, you’re optimistic
If your target is earlier than your
prediction, you’re optimistic
Prediction
Target
If your commitment is earlier than
your target, you’re planning to fail
If your commitment is earlier than
your target, you’re planning to fail
Commit
Target
If you miss your commitment, other
people will fail to meet their
targets
If you miss your commitment, other
people will fail to meet their
targets
Commit
Target
The importance of
syntax, semantics,
and idiom
Syntax is the way statements are
constructed
Correct syntax means your code
will run
Semantics give the meaning of the
language
Correct semantics mean your code
will do what you expect
Idiom is about writing code in an
expected way
Correct idiom means another
developer will understand
Code is written for people, not for
machines
You are not a
platform choice
You are a developer
Know Ruby? Learn some Rust
Know Java? Learn some Python
Know C#? Learn some Ruby
Know Visual Basic? Learn some F#
Know JavaScript? Learn some C
The more technology you
experience, the better you become
Career
development is
your responsibility
Read a book for career growth
every month
Learn a new language every year
If you’re not embarrassed by code
you wrote six months ago, you’re
not growing
The real world is
more complex than
you think
Time is such a simple thing
Years can have 366 days
Minutes can have 61 seconds
Days can have 26 hours
Some times happen twice or don’t happen
at all
Not all time zones are whole hours
Not all seconds are 1000ms long
Names are such simple things
A person has exactly one name
People have first names and last names
Names don’t change
Names are case insensitive
Prefixes and Suffixes can be ignored
Families share a common name
Names are assigned at birth
Characters are such simple things
“/𐐞𐐞”.EndsWith(“/”) == true
char.IsLetterOrDigit(“𐐞”) == true
char.IsLetter(“𐐞”) == true
Addresses are such simple things
I think you get the point.
In Closing
The job is not to write code
You’re paid to think
Software development is a team sport
No matter how careful you are, you will make
mistakes
The impossible happens
How to answer “How long?”
The importance of syntax, semantics, and idiom
You are not a platform choice
Career development is your responsibility
The real world is more complex than you think
To be a great developer
you need two things:
Willingness to feel totally
lost;
Confidence that you will
eventually reach the
solution
@hanokhaloni
Hanokhaloni
hanokhaloni

Things senior developers should know