2019-02-11-highlight-the-pragmatic-programmer-part-01

This is a highlight and summary content for my favorite parts

PREFACE

What Makes a Pragmatic Programmer?

  • Early adopter/fast adapter: instinct for technologies, love trying things out

  • Inquisitive: be a pack rat for little facts

  • Critical thinker: rarely take things as given without first getting the facts

  • Realistic: understand the underlying nature of each problem you face

  • Jack of all trades: try hard to be familiar with a board range of technologies and environments

    We're challenging you to THINK about WHAT you're DOING WHILE you're DOING

Chaper 1: A Pragmatic Philosophy

The Cat Ate My Source Code

One of the cornerstones of the pragmatic philosophy is the idea of taking respnsibility for yourself and your actions.

Take Responsibility

You have the right NOT to take on a responsibility for an impossible situation, or one in which the risks are too great. When you DO accept the responsibility for an outcome, you should expect to be held accountable for it.

Make a mistake or an error in judgment -> admit it honestly and try to offer options. Don't BLAME, or make up an excuse. Provide solutions.

If the disk crashes-taking all of your code with it-and you don't have a backup, it's YOUR FAULT.

"The cat ate my source code", won't cut it. Before tell anyone why something can't be done, stop and listen to yourself first. Does it reasonable? or stupid?

Before you go and tell them the bad news, is there anything else you can try? Instead of excuses, provide options.

Don't say it can't be done; explain what can be done to salvage the situation. How to prevent it from happening again?

Software Entropy

Don't live with Broken Windows. Fix each one as soon as it is discovered.

Take some action to prevent further damage and to show that you're on top of the situation.

Good-Enough Software

You can discipline yourself to write software that's good enough-good enough for yours users, for future maintainers, for your own peace of mind.

Know when to stop

Dont' spoil a perfectly good program by overrembellishment and overrefinement. Move on, and let your code stand in its own right for a while.

Your Knowledge Porfolio

Your knowledge and experience are your most important professional assets.

Unfortunately, they're expiring assets. Your knowledge becomes out of date as new techniques, languages, and evironments are developed.

Goals

  • Learn at least one new language every year

  • Read a technical book each quater

  • Read nontechnical books, too

  • Take classes

  • Participate in local user groups

  • Experiment with different environments

  • Stay current

  • Get wired

Critical thinking

Think critically about what you read and hear

Communicate

We have to communicate on many levels. We spend hours in meetings, listening and talking. A large part of oour day is spent communicating, so we need to do it well.

Know what you want to say

Plan what you want to say. Write an outline. Then ask yourself, "Does it get acroos whatever I'm trying to say?". Refine it until it does.

Know your audience

You need to understand the needs, interests, and capabilities of your audien.

Choose your momment

As part of understand what your audience needs to hear, you need to work out what their priorities are. Make what you're saying relevent in time, as well as in content.

Sometimes all it takes is a simple question: "Is this a good time to talk about...?"

Choose a style

Adjust the style of your delivery to suit your audience: briefing, wide-ranging chat, reports, documents... If in doubt, ask

Make it look good

Your ideas are importent. They deserve a good-looking vehicle to convey them to your audience

Imvolve your audience

If possible, involve your readers with early drafts of your document

Be a listener

If you want people to listen to you, listen to them.

Get back to people

Always respond to e-mails and voice mails, even if the response is simply

Last updated