Tous nos rayons

Déjà client ? Identifiez-vous

Mot de passe oublié ?

Nouveau client ?

CRÉER VOTRE COMPTE
Clean Code - A Handbook of Agile Software Craftsmanship
Ajouter à une liste

Librairie Eyrolles - Paris 5e
Disponible en magasin

Clean Code - A Handbook of Agile Software Craftsmanship

Clean Code - A Handbook of Agile Software Craftsmanship

Robert C. Martin - Collection Robert C. Martin Series

464 pages, parution le 15/08/2008

Résumé

Even bad code can function. But if code isn't clean, it can bring a development organization to its knees. Every year, countless hours and significant resources are lost because of poorly written code. But it doesn't have to be that way.

Noted software expert Robert C. Martin presents a revolutionary paradigm with Clean Code: A Handbook of Agile Software Craftsmanship. Martin has teamed up with his colleagues from Object Mentor to distill their best agile practice of cleaning code "on the fly" into a book that will instill within you the values of a software craftsman and make you a better programmer-but only if you work at it.

What kind of work will you be doing' You'll be reading code-lots of code. And you will be challenged to think about what's right about that code, and what's wrong with it. More importantly, you will be challenged to reassess your professional values and your commitment to your craft.

Clean Code is divided into three parts. The first describes the principles, patterns, and practices of writing clean code. The second part consists of several case studies of increasing complexity. Each case study is an exercise in cleaning up code-of transforming a code base that has some problems into one that is sound and efficient. The third part is the payoff: a single chapter containing a list of heuristics and "smells" gathered while creating the case studies. The result is a knowledge base that describes the way we think when we write, read, and clean code.

Readers will come away from this book understanding

  • How to tell the difference between good and bad code
  • How to write good code and how to transform bad code into good code
  • How to create good names, good functions, good objects, and good classes
  • How to format code for maximum readability
  • How to implement complete error handling without obscuring code logic
  • How to unit test and practice test-driven development

This book is a must for any developer, software engineer, project manager, team lead, or systems analyst with an interest in producing better code.

L'auteur - Robert C. Martin

Robert C. Martin est développeur professionnel depuis 1970 et consultant logiciel international depuis 1990. Il est fondateur et directeur général de Object Mentor, Inc., une équipe de consultants expérimentés qui dispense auprès de clients du monde entier des conseils dans plusieurs domaines de l'informatique, comme C++, Java, C#, Ruby, l'orienté objet, les motifs de conception, UML, les méthodes agiles et l'eXtreme Programming.

Photographie : ©Par Angelacleancoder — Travail personnel, CC BY-SA 4.0

Autres livres de Robert C. Martin

Sommaire

  • Foreword
  • Introduction
  • On the Cover
  • Clean Code 1
  • There Will Be Code 2
  • Bad Code 3
  • The Total Cost of Owning a Mess 4
  • Schools of Thought 12
  • We Are Authors 13
  • The Boy Scout Rule 14
  • Prequel and Principles 15
  • Conclusion 15
  • Bibliography 15
  • Meaningful Names 17
  • Introduction 17
  • Use Intention-Revealing Names 18
  • Avoid Disinformation 19
  • Make Meaningful Distinctions 20
  • Use Pronounceable Names 21
  • Use Searchable Names 22
  • Avoid Encodings 23
  • Avoid Mental Mapping 25
  • Class Names 25
  • Method Names 25
  • Don't Be Cute 26
  • Pick One Word per Concept 26
  • Don't Pun 26
  • Use Solution Domain Names 27
  • Use Problem Domain Names 27
  • Add Meaningful Context 27
  • Don't Add Gratuitous Context 29
  • Final Words 30
  • Functions 31
  • Small! 34
  • Do One Thing 35
  • One Level of Abstraction per Function 36
  • Switch Statements 37
  • Use Descriptive Names 39
  • Function Arguments 40
  • Have No Side Effects 44
  • Command Query Separation 45
  • Prefer Exceptions to Returning Error Codes 46
  • Don't Repeat Yourself 48
  • Structured Programming 48
  • How Do You Write Functions Like This? 49
  • Conclusion 49
  • SetupTeardownIncluder 50
  • Bibliography 52
  • Comments 53
  • Comments Do Not Make Up for Bad Code 55
  • Explain Yourself in Code 55
  • Good Comments 55
  • Bad Comments 59
  • Bibliography 74
  • Formatting 75
  • The Purpose of Formatting 76
  • Vertical Formatting 76
  • Horizontal Formatting 85
  • Team Rules 90
  • Uncle Bob's Formatting Rules 90
  • Objects and Data Structures 93
  • Data Abstraction 93
  • Data/Object Anti-Symmetry 95
  • The Law of Demeter 97
  • Data Transfer Objects 100
  • Conclusion 101
  • Bibliography 101
  • Error Handling 103
  • Use Exceptions Rather Than Return Codes 104
  • Write Your Try-Catch-Finally Statement First 105
  • Use Unchecked Exceptions 106
  • Provide Context with Exceptions 107
  • Define Exception Classes in Terms of a Caller's Needs 107
  • Define the Normal Flow 109
  • Don't Return Null 110
  • Don't Pass Null 111
  • Conclusion 112
  • Bibliography 112
  • Boundaries 113
  • Using Third-Party Code 114
  • Exploring and Learning Boundaries 116
  • Learning log4j 116
  • Learning Tests Are Better Than Free 118
  • Using Code That Does Not Yet Exist 118
  • Clean Boundaries 120
  • Bibliography 120
  • Unit Tests 121
  • The Three Laws of TDD 122
  • Keeping Tests Clean 123
  • Clean Tests 124
  • One Assert per Test 130
  • F.I.R.S.T 132
  • Conclusion 133
  • Bibliography 133
  • Classes 135
  • Class Organization 136
  • Classes Should Be Small! 136
  • Organizing for Change 147
  • Bibliography 151
  • Systems 153
  • How Would You Build a City? 154
  • Separate Constructing a System from Using It 154
  • Scaling Up 157
  • Java Proxies 161
  • Pure Java AOP Frameworks 163
  • AspectJ Aspects 166
  • Test Drive the System Architecture 166
  • Optimize Decision Making 167
  • Use Standards Wisely, When They Add Demonstrable Value 168
  • Systems Need Domain-Specific Languages 168
  • Conclusion 169
  • Bibliography 169
  • Emergence 171
  • Getting Clean via Emergent Design 171
  • Simple Design Rule 1: Runs All the Tests 172
  • Simple Design Rules 2-4: Refactoring 172
  • No Duplication 173
  • Expressive 175
  • Minimal Classes and Methods 176
  • Conclusion 176
  • Bibliography 176
  • Concurrency 177
  • Why Concurrency? 178
  • Challenges 180
  • Concurrency Defense Principles 180
  • Know Your Library 182
  • Know Your Execution Models 183
  • Beware Dependencies Between Synchronized Methods 185
  • Keep Synchronized Sections Small 185
  • Writing Correct Shut-Down Code Is Hard 186
  • Testing Threaded Code 186
  • Conclusion 190
  • Bibliography 191
  • Successive Refinement 193
Voir tout
Replier

Caractéristiques techniques

  PAPIER
Éditeur(s) Prentice Hall
Auteur(s) Robert C. Martin
Collection Robert C. Martin Series
Parution 15/08/2008
Nb. de pages 464
Format 17,8 x 23,4
Couverture Broché
Poids 680g
Intérieur Noir et Blanc
EAN13 9780132350884
ISBN13 978-0-13-235088-4

Avantages Eyrolles.com

Livraison à partir de 0,01 en France métropolitaine
Paiement en ligne SÉCURISÉ
Livraison dans le monde
Retour sous 15 jours
+ d'un million et demi de livres disponibles
satisfait ou remboursé
Satisfait ou remboursé
Paiement sécurisé
modes de paiement
Paiement à l'expédition
partout dans le monde
Livraison partout dans le monde
Service clients sav@commande.eyrolles.com
librairie française
Librairie française depuis 1925
Recevez nos newsletters
Vous serez régulièrement informé(e) de toutes nos actualités.
Inscription