Video: Unconditional Code - Michael Feathers
Unconditional Code - Michael Feathers
(https://www.youtube.com/watch?v=AnZ0uTOerUI)
data:image/s3,"s3://crabby-images/3029f/3029f5010d3bc5a89c5b77517ec49d6c3663fdba" alt=""
data:image/s3,"s3://crabby-images/6c3dd/6c3dde1841196d950ec7fa449e0530068b1c6d6c" alt=""
Null Object Pattern
data:image/s3,"s3://crabby-images/230ab/230ab0e28c69636802fdaa7cf947be734897ba22" alt=""
something bad has happened, but we'll act like it didn't
others: NaN, [], null, special case
data:image/s3,"s3://crabby-images/b9c1c/b9c1c9f90875beadeafd200b31bd6872ab1b2646" alt=""
that error is part of our domain
same in functional
data:image/s3,"s3://crabby-images/fd8c0/fd8c0f1dcca1a1b289d673459e1fba0a1f499bc2" alt=""
data:image/s3,"s3://crabby-images/f33c4/f33c4f334ba362bc06510bf994ae49e9d2f464e5" alt=""
error has moved to the place where the error occurred
data:image/s3,"s3://crabby-images/4fdb9/4fdb9bf789631ced43fdf1a0aa8d456a3b7b41be" alt=""
when successful, do this
data:image/s3,"s3://crabby-images/07558/075586c2c08fe62e29bbcb96b7a958bee5497b2d" alt=""
data:image/s3,"s3://crabby-images/f40e0/f40e09fc0e36f36b6040a2a5d3eeb19bea61abb9" alt=""
---
Example
data:image/s3,"s3://crabby-images/6cf84/6cf8459fd0f6299655d362edb6ed37bc8d1da6d5" alt=""
count # groups of '1' (blue here)
data:image/s3,"s3://crabby-images/0ac14/0ac147ae2d488f04eb73f80e0530e96dd488e3dd" alt=""
"edgy code", it has a lot of edge cases
data:image/s3,"s3://crabby-images/e958b/e958b83b7652b189b313d5f6bc6a3fe08d550646" alt=""
add 0 at front, removes one edge
data:image/s3,"s3://crabby-images/734d1/734d1d740a36b52318d58d77973c3430854e21a6" alt=""
we eliminated an edge, by extending the domain
example
data:image/s3,"s3://crabby-images/7b8fb/7b8fb7771c2fa4635e79f54102840be78f9af0bc" alt=""
data:image/s3,"s3://crabby-images/b4168/b416850bc5d75b25e072441104dff72ab347abc6" alt=""
data:image/s3,"s3://crabby-images/34943/3494304bb2dec8f9e7540c98f063a9ee0a5c05e1" alt=""
data:image/s3,"s3://crabby-images/9ea96/9ea96de46515cc0f0649daf8584f1ffb03083475" alt=""
makes it more general, can now work with multiple files
generalizing the problem a bit, so that things that can occur can be okay
data:image/s3,"s3://crabby-images/1c27a/1c27a393bd435df72b1dbd87e6bc55e6399f054a" alt=""
data:image/s3,"s3://crabby-images/b9c10/b9c10fba1d3f1a38d606560aa837b64b2acdd379" alt=""
extend the range of input
so some things are not an error
not here:
data:image/s3,"s3://crabby-images/0d650/0d650c5dc61b3d7fad3b93d0048a31538b0a07b8" alt=""
we do here:
data:image/s3,"s3://crabby-images/d57d7/d57d70e9f4cdf5250a0f73539a31fb07438da8da" alt=""
make a bet: when you extend the domain, people will understand that
data:image/s3,"s3://crabby-images/6a221/6a221ea61aed83a596d5efed1df45438793a5e93" alt=""
data:image/s3,"s3://crabby-images/22395/2239537a56caab932054a47b386713dc0ef62ac8" alt=""
data:image/s3,"s3://crabby-images/8b21c/8b21ccbfa846d035f98b474e6fc516db8eaae8af" alt=""
2 parts of the program
1) checking
2) do stuff
data:image/s3,"s3://crabby-images/b0d05/b0d05c8a4b0f2c67e6878235f9bc76d0df2779ca" alt=""
area where there is no need of error checking
option monad in haskell, mimicked in haskell)
data:image/s3,"s3://crabby-images/ec737/ec737afcd5f2b37c4beb26501553a132c05795f8" alt=""
output =
- cumulative error message
- or
- actual output
=> mixed feeling
data:image/s3,"s3://crabby-images/42f8c/42f8c0c6a78bf0df0cf41319319f136f5ce0a6d2" alt=""
exceptions should be like a time machine
(like transactions)
intention can succeed or fail
example: shuffle
data:image/s3,"s3://crabby-images/d9108/d9108bbaf700d18374447d86ef13c87b465cbddd" alt=""
5 why when designing
data:image/s3,"s3://crabby-images/c4e2f/c4e2f185b5db53a215e7592698948045fb4283ed" alt=""
error handling: distance between detecting problem and what you go and do about it
if I can't read a config, can I use a default config + notify?
always question errors
can't eliminate entirely
but can we restructure the system so as to remove this error?
tended systems vs untended systems
data:image/s3,"s3://crabby-images/0e7cd/0e7cd2b0f9809fa17b3a65ec56c63c74e90e1a44" alt=""
data:image/s3,"s3://crabby-images/48567/485678981748659fae5757b9afef13980d3caed7" alt=""
data:image/s3,"s3://crabby-images/2b6ac/2b6acdbe4ace1af1f93ca939b4575ef743991215" alt=""
data:image/s3,"s3://crabby-images/5d76d/5d76d894e02d8e3d029e298292059fa2c7bdf392" alt=""
supervisor trees = mimic the human
cost choice
safety choice
data:image/s3,"s3://crabby-images/8ac0b/8ac0baf864849221ad52e9c026d05a0bf282a1b1" alt=""
data:image/s3,"s3://crabby-images/7d465/7d4656e77667cd719ba5cd46057d7e372a1fe6f0" alt=""
data:image/s3,"s3://crabby-images/02601/02601990f55d9c1eb8deb4e6324fa4dd648c49f3" alt=""
counter-intuitive
data:image/s3,"s3://crabby-images/ce7d1/ce7d178aedd4aa44900e974213bcacc6534f3877" alt=""
care happens when there is hazard
vs:
rust - prevent things from happening
erlang - react to when they happen
data:image/s3,"s3://crabby-images/e30d5/e30d504a50a00941c96bacf32b0f5d9228d263bf" alt=""