Book Image

Understanding Software

By : Max Kanat-Alexander
Book Image

Understanding Software

By: Max Kanat-Alexander

Overview of this book

In Understanding Software, Max Kanat-Alexander, Technical Lead for Code Health at Google, shows you how to bring simplicity back to computer programming. Max explains to you why programmers suck, and how to suck less as a programmer. There’s just too much complex stuff in the world. Complex stuff can’t be used, and it breaks too easily. Complexity is stupid. Simplicity is smart. Understanding Software covers many areas of programming, from how to write simple code to profound insights into programming, and then how to suck less at what you do! You'll discover the problems with software complexity, the root of its causes, and how to use simplicity to create great software. You'll examine debugging like you've never done before, and how to get a handle on being happy while working in teams. Max brings a selection of carefully crafted essays, thoughts, and advice about working and succeeding in the software industry, from his legendary blog Code Simplicity. Max has crafted forty-three essays which have the power to help you avoid complexity and embrace simplicity, so you can be a happier and more successful developer. Max's technical knowledge, insight, and kindness, has earned him code guru status, and his ideas will inspire you and help refresh your approach to the challenges of being a developer.
Table of Contents (50 chapters)
Understanding Software
Credits
About the Author
www.PacktPub.com
Customer Feedback
Foreword
2
The Engineer Attitude
3
The Singular Secret of the Rockstar Programmer
4
Software Design, in Two Sentences
5
Clues to Complexity
6
Ways To Create Complexity: Break Your API
7
When Is Backwards-Compatibility Not Worth It?
8
Complexity is a Prison
10
The Accuracy of Future Predictions
11
Simplicity and Strictness
12
Two is Too Many
14
What is a Bug?
24
What is a Computer?
25
The Components of Software: Structure, Action, and Results
27
Software as Knowledge
30
Simplicity and Security
34
How We Figured Out What Sucked
36
Why Programmers Suck
38
Developer Hubris
39
"Consistency" Does Not Mean "Uniformity"
42
Success Comes from Execution, Not Innovation
Index

Skipping a Step


Another specialized understanding problem is when you've skipped some step in the proper sequence of development. For example, let's say our Bike object depends on the Wheels, Pedals, and Frame objects. If you try to write the whole Bike object without writing the Wheels, Pedals, or Frame objects, you're going to have to think a lot about those non-existent classes. On the other hand, if you write the Wheels class when there is no Bike class at all, you might have to think a lot about how the Wheels class is going to be used by the Bike class.

Don't jump over steps in the development of your system and expect that you'll be productive.

The right approach in the example above, would be to implement enough of the Bike class to get to the point where you need Wheels. Then write enough of the Wheels class to satisfy your immediate need in the Bike class. Then go back to the Bike class, and work on that until the next time you need one of the underlying pieces. So just as I suggested...