Software Craftsmanship : The New Imperative

個数:

Software Craftsmanship : The New Imperative

  • 在庫がございません。海外の書籍取次会社を通じて出版社等からお取り寄せいたします。
    通常6~9週間ほどで発送の見込みですが、商品によってはさらに時間がかかることもございます。
    重要ご説明事項
    1. 納期遅延や、ご入手不能となる場合がございます。
    2. 複数冊ご注文の場合、分割発送となる場合がございます。
    3. 美品のご指定は承りかねます。
  • 【入荷遅延について】
    世界情勢の影響により、海外からお取り寄せとなる洋書・洋古書の入荷が、表示している標準的な納期よりも遅延する場合がございます。
    おそれいりますが、あらかじめご了承くださいますようお願い申し上げます。
  • ◆画像の表紙や帯等は実物とは異なる場合があります。
  • ◆ウェブストアでの洋書販売価格は、弊社店舗等での販売価格とは異なります。
    また、洋書販売価格は、ご注文確定時点での日本円価格となります。
    ご注文確定後に、同じ洋書の販売価格が変動しても、それは反映されません。
  • 製本 Paperback:紙装版/ペーパーバック版/ページ数 208 p.
  • 言語 ENG
  • 商品コード 9780201733860
  • DDC分類 005.1

Full Description

Software Craftsmanship is a call to arms for programmers: an impassioned manifesto that restores the developer to a central role in large-scale projects, and shows developers how to master the skills they need to succeed in that role. Software Craftsmanship transcends "software engineering," demonstrating that quality software can't simply be "manufactured": it must be built by craftspeople with pride in their work, and a personal commitment to excellence. In Software Craftsmanship, Pete McBreen focuses on the craft of software development, explaining why current "software engineering" techniques often fail, and offering programmers a new path to excellence. Just as the modern carpenter benefits from better tools, materials, and understanding, the modern programmer can benefit from better computers, reusable components, and more robust languages -- but only if he or she is prepared to treat the software profession as a true "craft." McBreen explains what software "craftsmanship" means, how its affects users, and how it changes the developer's relationship with customers. He introduces the concepts of software apprentices and journeymen, shows what can (and can't) be learned from the software engineering movement, and presents specific steps you can take now to move towards craftsmanship in your work -- and your organization.

Contents

Preface.
I. QUESTIONING SOFTWARE ENGINEERING.

1. Understanding Software Engineering.


The Paradox of Software Engineering.



The Modern Definition of Software Engineering.



Is Software Engineering a Good Choice for Your Project?

2. The Problems with Software Engineering.


Can Software Development Be Made Systematic and Quantified?



The Hazards of the Good Enough Software Approach.



What Is the Alternative to Software Engineering?

3. Understanding Software Development.


Software as Capital.



Does the Division of Labor Work for Software Development?



One Size Does Not Fit All.

4. Finding a Better Metaphor Than Software Engineering.


Finding a Better Metaphor Than Software Engineering.



The Craft of Software Development.



Parallels with Traditional Craftsmanship.



The Resurgence of the Craft of Software Development.

II. SOFTWARE CRAFTSMANSHIP.

5. Putting People Back into Software Development.


Craftsmanship Is About Getting Better at Software Development.



Craftsmanship Encourages Developers to Write Great Software.



A Call to Arms.

6. Craftsmanship Is the Opposite of Licensing.


Craftsmanship Is Personal.



Licensing Is an Illusion.



Craftsmanship Focuses on the Individual.

III. IMPLICATIONS OF SOFTWARE CRAFTSMANSHIP.

7. How Craftsmanship Affects the Users of Systems.


Software Craftsmanship Works Because Software Is Easy to Copy.



Craftsmen Have a Different Relationship with Their Users.



Great Software Deserves to Be Signed.



Craftsmen Need Demanding Users.



Software Craftsmanship Leads to Collaborative Development.

8. Customers Have a Different Relationship with Craftsmen.


Setting Realistic Delivery Dates.



Exposing the Fallacy of Good Enough Software.



Allowing Software Craftsmen to Take Credit for Their Work.



Start Exploiting the Difference in Productivity Between Developers.



But How Do We Know How Good a Developer Really Is?



Customers Make a Cost/Quality Trade-off When Choosing Craftsmen.



Customers Have Long Term Relationships with Software Craftsmen.



Customer Interests Are Aligned with the Interests of Software Craftsmen.

9. Managing Craftsmen.


Software Craftsmen Are Not Hired Hands.



Good Developers Are More Valuable Than Their Managers.



Software Craftsmen Have a Different Relationship with Their Managers,



Managing Great Developers Is a Pleasure and a Privilege.



Software Craftsmen Like Creating Applications.



Managing Software Craftsmen Is Different.



Software Craftsmen Push for What They Need.

10. Becoming a Software Craftsman.


Software Craftsmanship Is a Rejection of Narrow Specialization.



Craftsmanship Requires Dedication.



How Does a Person Become a Software Craftsman?



The Craft Tradition Has Endured for Centuries.

11. Mastering the Craft.


What Does a Master Software Craftsman Look Like?



Use Your Old-timers.



Mastery Implies the Use of Stable Technologies.



Developing Mastery Takes Time.



Mastery Implies Taking Responsibility for Passing on the Craft.

12. Apprentice Developers.


We Must Reverse the Decline in the Quality of Developer Training.



Becoming an Apprentice Is a Significant Step.



Apprenticeship Instills Lifelong Learning.



The Role of Apprentices.



An Apprenticeship Is a Significant Investment of Time and Energy.

13. Journeymen Developers.


Where Journeymen Fit in the Craft Tradition.



Journeymen Developers.



Journeymen Are Focused on Delivering Applications.



Journeymen Play a Key Role in Software Craftsmanship.

IV. REPOSITIONING SOFTWARE ENGINEERING.

14. Software Engineering Projects.


Software Engineering Is Designed for Large Systems Projects.



Software Engineering Projects Are Diverse and Varied.

15. Hazards of the Software Engineering Metaphor.


You Cannot Do Software Engineering on a Low Budget.



Software Engineering Encourages Scientific Management.



Software Factories: The Production Line for Software.



Reuse over Time Is Hazardous.



The Myth of the Standardized Software Development Process.



Software Engineering Forces Us to Forget the Individual.



We Need More Variety in Our Development Processes, Not Less.

16. Learning from Software Engineering.


Size and Complexity Matter.



Applications Need to Be Well Structured.



Change Can Be Expensive Unless You Allow for It.



Communication Inside the Team and with Users Is Crucial.



Producing Accurate Estimates Is Very Expensive.

V. WHAT TO DO ON MONDAY MORNING.

17. Experience— The Best Indicator of Project Success.


Choose Software Craftsmen Based on Their Reputations.



Evaluate Craftsmen Based on Their Reputations and Portfolio.



Auditioning a Software Craftsman.



Let Your Software Craftsman Pick the Rest of the Development Team.



Collaborative Development.



Avoid Bleeding-Edge Technology If At All Possible.



Paying for Experience.



Be Prepared to Be Amazed.



Design for Testing and Maintenance.



Think Applications, Not Projects.



Maintenance Teams Should Refuse to Accept Bad Applications.

18. Design for Maintenance.


Software Craftsmen Prefer Nonproprietary, Open Source Tools.



Great Software Is Global.



Software Craftsmen Need to Fight Back Against Planned Obsolescence.



Great Software Needs to Be Given a Great User Interface.



Maintainable Software Is Easy to Diagnose.



The Hazards of Outsourcing.



You Can Still Use Outside Craftsmen to Create Your Application.



Maintenance Is the Most Important Part of the Life of Any Application.



Not All Software Has to Be Maintainable.



Design for Testing and Maintenance Is Not Rocket Science.

19. Perpetual Learning.


Creating a Learning Environment.



Mastering the Craft of Software Development.



Choose Training Courses Very Carefully.



Encourage Your People to Be Visible in the Software Development Community.



Becoming a Reflective Practitioner.

Epilogue.
Acknowledgements.
Index. 0201733862T08072001