Video: Software that Fits in Your Head - Dan North
Video: Software that Fits in Your Head - Dan North |
Software that Fits in Your Head - Dan North
data:image/s3,"s3://crabby-images/e5739/e57398096f04f7920ef574e633df43b6d988e7ec" alt=""
data:image/s3,"s3://crabby-images/61ff6/61ff6c007d7d0f72aaf5615523f73d33ca54ffed" alt=""
data:image/s3,"s3://crabby-images/bbe5d/bbe5d73f9c69c87d874e39d302bcc4d66b48d24d" alt=""
software is not the point
productive != effective
data:image/s3,"s3://crabby-images/d3a02/d3a022074ec301b3cd7d95d47da59bd707f13c6e" alt=""
to getting the business impact
data:image/s3,"s3://crabby-images/03adc/03adcf01702c2e3cfb84ddd925f9624944501cb2" alt=""
understanding code
code I know (new
code no-one knows (middle)
code everyone knows
cared for
data:image/s3,"s3://crabby-images/2ce3a/2ce3a9f2448fe32c3e7a0850189951f940e58985" alt=""
entropy
data:image/s3,"s3://crabby-images/d4119/d41196f7390016019b886e604b0448ca22e09a52" alt=""
Short software Half-Life
half-life (physics) know precisely half will decay in certain time, dunno which
How long would you need to go away, before half of the code has been completely rewritten?
typically years
~6weeks
fearlessly rewrite code
I know more now
design considerations
data:image/s3,"s3://crabby-images/4fb68/4fb6867099848fa5276e8b3689264b34a91296e5" alt=""
well written code shows
what it does
NOT purpose
NOT what is not there (decisions)
purpose: why it's there
responsibility: what it owns (and what not)
lifecycle
data:image/s3,"s3://crabby-images/7692c/7692c57046e787a7751081f4f24bf5bb40e4c4ed" alt=""
documentation = why something is there
write component test and docs
TDD != tests
Article: Mike Nigard, architecture decision records
decision we made
people who made it
things we considered
things we discarded
so this we ended
extra credit:
this is the problem it solves
these risks are introduced
-> stays in version control
static != stable
data:image/s3,"s3://crabby-images/854f7/854f7357617c1e74b24d5d3d0f38080f00ec88d7" alt=""
complexity metric:
"bigger than my head"
if have to page up and down, it's too much
coping mechanisms
analysis
actively ignoring
mocking and stubbing
painkillers for complexity
what fits in my head?
language
clojure
1 way to do something
scala
least opinionated
multiple dialects in 1 code base
framework
data:image/s3,"s3://crabby-images/4b67d/4b67d38f0c23d6cc56a0eca94f6d47689fe73919" alt=""
what would James do?
shared values
data:image/s3,"s3://crabby-images/3d3c7/3d3c715977fc062d9f2d7e716f06ca9b888cf9fe" alt=""
microservices?
data:image/s3,"s3://crabby-images/2edaf/2edafb614bf249f1931514d61d72bcdb1a4cf322" alt=""
hard shell
pass messages
"little computers passing messages"
-- Alan K
-> inventor of OO
object != entity
object does things with entities
think about component by looking at the messages
microservices!
data:image/s3,"s3://crabby-images/37fd5/37fd5a31cfe2f6a69748a3403206980e99617a2e" alt=""
closing message
data:image/s3,"s3://crabby-images/30163/3016396b8cbde49f69be933f36f2d6427d690bbe" alt=""
Video: Software that Fits in Your Head - Dan North |