2019-02-15-highlight-the-pragmatic-programmer-part-03
This is a highlight and summary content for my favorite parts
Chapter 4: Pragmatic paranoia
You can't write perfect software
The analogy with coding is pretty obvious. So we are taught to code defensively. If there are any doubt, we validate all information we're given.
Chapter 5: Bend, or Break
Life doesn't stand still. In order keep up with today's near-frantic pace of change, we need to write code that as loose - ass flexible - as posible. Otherwise, we may findout code quickly becoming outdated.
Decoupling and the Law of the Demeter
Minimizie coupling
Need to be carefule how many other modules you interact with, and more importantly, how you came to interact with them.
Metaprogramming
Everytime we have to go in and change the code to accommodate some change in business logic, we run the risk of breaking the system - of introducing a new bug.
So we say "out of the details", get them out of the code. While we're at it, we can make our code highly configurable and "soft"-that is easily adaptable to changes.
Dynamic configuration
We want to make our systems highly configutable. Not just things such as texts, colors, but deeply ingranted items such as algorithms, database products, middleware technology,...
Configure, don't integrate
Use metadata to describe configuration options.
Metadata-Driven Application
Our goal is to think declaratively, and create highly dynamic and adaptable programs. We do this by adopting a general rule: program for the general cases, and put the specific somewhere else - outside the compiled code base
Put abstractions in code, details in metadata
Define most details untils the last moment, and leave the details as soft as posible.
Chapter 6: While you are coding
Avoid programming by coincidence-replying on luck and accidental successes-in favor of programming deliberately
Program by Coincidence
Doesn't know why the code is failing because didn't know why it worked in the first place.
Accidents of Implementation
It's easy to be fooled by this line of thought: "It works now, better leave well enough alone..."
Implicit Assumptions
It's easy to assume that X causes Y. DON'T ASSUME it, prove it.
How to Program Deliberately
Always be aware of what you are doing
Proceed from a plan, whether that plan is in your head, on the back of the cocktail napkin, or on a wall-sized
Rely on reliable things
Dont be a salve to history
Algorithm Speed
There is a kind of estimating that programmers use almost daily: estimating the resources that algorithms use - time, processor, memory, and so on.
It's a good idea to make sure an algorithm really is a bottleneck before investing your precious time trying to improve it.
Refactoring
Change and decay in all around I see
As a program evolves, it will become neceessary to rethink earlier decisions and rework portions of the code. The progress is perfectly natural.
Evil Wizards
Don't use wizard code you don't understand
Last updated