Martin Fowler quotes:

+1
Share
Pin
Like
Send
Share
  • One of the things I've been trying to do is look for simpler or rules underpinning good or bad design. I think one of the most valuable rules is avoid duplication. "Once and only once" is the Extreme Programming phrase.

  • Never in the annals of software engineering was so much owed by so many to so few lines of code

  • In almost all cases, I'm opposed to setting aside time for refactoring. In my view refactoring is not an activity you set aside time to do. Refactoring is something you do all the time in little bursts.

  • It is impossible not to notice Ruby on Rails. It has had a huge effect both in and outside the Ruby community... Rails has become a standard to which even well-established tools are comparing themselves to.

  • When you actually sit down to write some code, you learn things that you didn't get from thinking about them in modeling terms...there is a feedback process there that you can only really get at from executing some things and seeing what works

  • Any fool can write code that a computer can understand. Good programmers write code that humans can understand.

  • Comparing to another activity is useful if it helps you formulate questions, it's dangerous when you use it to justify answers.

  • One of the big dangers is to pretend that you can follow a predictable process when you can't.

  • The biggest issue on software teams is making sure everyone understands what everyone else is doing.

  • ...if you're afraid to change something it is clearly poorly designed.

  • A pattern is an idea that has been useful in one practical context and will probably be useful in others.

  • Comprehensiveness is the enemy of comprehensibility.

  • Continuous Integration is a software development practice where members of a team integrate their work frequently, usually each person integrates at least daily - leading to multiple integrations per day. Each integration is verified by an automated build (including test) to detect integration errors as quickly as possible. Many teams find that this approach leads to significantly reduced integration problems and allows a team to develop cohesive software more rapidly.

  • I can only think of so many good ideas in a week. Having other people contribute makes my life easier.

  • I can't choose whether someone is offended by my actions. I can choose whether I care.

  • I find that writing unit tests actually increases my programming speed

  • If you're a technical lead, you need to be coding.

  • I've learned to always avoid saying "always"

  • Now I'm a pretty lazy person and am prepared to work quite hard in order to avoid work.

  • So I hope I've made clear that imposing agile methods is a very red flag.

  • When to use iterative development? You should use iterative development only on projects that you want to succeed.

  • Why is composing symphonies tough? I don't know. It's just very few people in the world can do it well. And I think that's the case with upfront design. It is very hard to do well.

+1
Share
Pin
Like
Send
Share