Clean Code

  • This a controversial topic. As is opinionated and no set standard.

    • Depends on the cirucmstances of the code

      • Type of codebase

      • Industry

      • current practices

      • etc

  • This should be enforced from a teams/department perspective for short and long term needs, defined and refined by the most experienced and respected developers.

    • And part of code reviews, and pairing.

    • Used in static analysis tests

    • Shared via learnings, brown bags etc

    • Part of assessment for promotions

    • Should have must do and could do parts

  • Probably never achieve

Clean code - Bob Martin

  • A book of high repute, espousing many opinionated standards for writing clean code

  • Giving to many new junior devs

    • Good standards to start off with, but must make sure they fit in with the current clean code patterns already in use

    • Eventually, deciding its trade offs and when to or not use

  • A people take it as gospal, rather than using it as ideas with trade offs

    • This happens due to the popularity of the author rather than content

  • clean code can be different for different codebases, different companies etc

Counter

  • https://qntm.org/clean

  • https://dev.to/remojansen/clean-code-is-considered-harmful-3lh0

Issues

  • In my work I don't care about nanoseconds. I almost never care about microseconds. I sometimes care about milliseconds. Therefore I make the software engineering tradeoff towards programmer convenience, and long term readability and maintainability. This means that I don't want to think about the hardware. I don't want to know about Ln caches, or pipelining, or SIMD, or even how many cores there are in my processor. I want all that abstracted away from me, and I am willing to spend billions of computer cycles to attain that abstraction and separation. My concern is programmer cycles not machine cycles.

    • I have, in the past, worn the other shoes. There was a time in my career when microseconds had to be conserved, when I had to meet submillisecond deadlines, and I counted and conserved cycles as carefully as Ebenzer Scrooge. So I think I understand your concern fairly well.

    • clean code will be trading computer cycles for programmer cycles. And that's a good thing in most of the software teams and organizations

  • https://youtu.be/DsAclZbP_Us Abstraction Bad? | Clean Code : Horrible Performance : (Clip) Interview

    • Make code clean too fast or too early can be issue, this is predictive abstraction, and we cannot predict the future.

      • unless we know the future requirements that will be worked in or soon or later

    • It's better to write the simplest code, may not have all the patterns and solid etc, but it works, and when it needs to be changed then do it at that time

      • ie 3 times then abstract

  • https://www.youtube.com/watch?v=_Zqhs1IhGx4&t=1s

    • http://www.jeremybytes.com/Demos.aspx#CC

  • https://betterprogramming.pub/clean-code-is-slow-but-you-still-need-it-anyway-ffcac6973c93

  • https://www.reddit.com/r/csharp/comments/1cwbv37/is_clean_code_dead/

Last updated