Simplifying Software Design: The Genius of Bureaucracies, or How Not-My-Job Sharpens Your Design addresses a deceptively simple question at the heart of software development:

  • Where should this line of code go?

Every system is the accumulation of answers to that question. Each decision about responsibility, knowledge, and communication shapes whether a system remains understandable, maintainable, and adaptable-or becomes tangled and fragile.

In this book, international software design guru Dr Alistair Cockburn offers a practical answer using an unexpected metaphor: design your software the way you would design a bureaucracy!

While bureaucracies are often criticized, they excel at defining clear responsibilities, limiting who needs to know what, and structuring communication between roles. These same properties are essential for effective software design.

Two familiar human reflexes become precise design tools:

  • "Not my job" - keeps responsibilities sharply defined
  • "No need to know" - limits unnecessary dependencies

Using these principles, developers can decide where behavior belongs, reduce coupling, and create systems that remain clear as they grow.

Just as relevant at this time, they question arises: "How do we train AI systems to produce maintainable code?" It turns out that AI have read all our complaints about bureaucracies and understand "Not my job" and "No need to know" very well. These questions make for excellent dialog with them.

Building on responsibility-driven design (Ward Cunningham, Kent Beck, Rebecca Wirfs-Brock), the book presents a compact starter kit for software design. It introduces responsibility statements, scenario-based evaluation, and interaction diagrams as practical techniques for exploring and improving designs.

Cockburn also presents six design tests-Abstraction, Responsibility Alignment, Evolution,Communication Patterns, Data Connectedness, Data Variations-to help compare alternatives and reason about how a system will respond to change. Rather than defining a single "correct" design, the book focuses on how different designs support different futures.

These ideas are connected to familiar architectural styles, including Model-View-Controller and hexagonal architecture (ports and adapters), showing how responsibility and boundary management apply at every scale-from subsystems to individual classes.

Written as part of the Simplifying series, this book focuses on the small set of techniques that deliver the greatest practical value. It is accessible to newcomers while offering a clear framework for experienced developers and architects.

In an era of AI-assisted programming, where code can be generated rapidly, clear boundaries and responsibilities remain essential. These techniques help teams-and the tools they use-produce systems that are modular, understandable, and resilient over time.



Autorentext

Dr. Alistair Cockburn (pronounced CO-BURN) was named as one of the "42 Greatest Software Professionals of All Times" in 2020, as a world expert on methodologies, project management,software architecture, use cases and agile development. He co-authored both the Agile Manifesto and the Project Management Declaration of Inter-dependence. Since 2015 he has been working on expanding agile to cover every kind of initiative, including social impact project,governments, and families. For his latest work, see https://alistaircockburn.com/.

Titel
Simplifying Software Design: The Genius of Bureaucracies, or How Not-My-Job Sharpens Your Design (The Simplifying Series)
EAN
9798998586286
Format
E-Book (epub)
Veröffentlichung
17.03.2026
Digitaler Kopierschutz
Adobe-DRM
Dateigrösse
8.26 MB