Difference between revisions of "Design by contract"
Karl Jones (Talk | contribs) (→External links) |
Karl Jones (Talk | contribs) (→External links) |
||
(One intermediate revision by the same user not shown) | |||
Line 15: | Line 15: | ||
* [[Component-based software engineering]] | * [[Component-based software engineering]] | ||
* [[Computer programming]] | * [[Computer programming]] | ||
+ | * [[Correctness (computer science)]] | ||
+ | * [[Defensive programming]] | ||
+ | * [[Fail-fast]] | ||
+ | * [[Formal methods]] | ||
+ | * [[Hoare logic]] | ||
+ | * [[Modular programming]] | ||
+ | * [[Program derivation]] | ||
+ | * [[Program refinement]] | ||
* [[Software engineering]] | * [[Software engineering]] | ||
+ | * [[Test-driven development]] | ||
== External links == | == External links == | ||
Line 26: | Line 35: | ||
[[Category:Software]] | [[Category:Software]] | ||
[[Category:Software development]] | [[Category:Software development]] | ||
+ | [[Category:Software engineering]] |
Latest revision as of 18:40, 9 May 2016
Design by contract (DbC), also known as contract programming, programming by contract and design-by-contract programming, is an approach for designing software.
Description
Design by contract prescribes that software designers should define formal, precise and verifiable interface specifications for software components, which extend the ordinary definition of abstract data types with preconditions, postconditions and invariants.
These specifications are referred to as "contracts", in accordance with a conceptual metaphor with the conditions and obligations of business contracts.
The DbC approach assumes all client components that invoke an operation on a server component will meet the preconditions specified as required for that operation.
Where this assumption is considered too risky (as in multi-channel client-server or distributed computing) the opposite "defensive design" approach is taken, meaning that a server component tests (before or while processing a client's request) that all relevant preconditions hold true, and replies with a suitable error message if not.
See also
- Component-based software engineering
- Computer programming
- Correctness (computer science)
- Defensive programming
- Fail-fast
- Formal methods
- Hoare logic
- Modular programming
- Program derivation
- Program refinement
- Software engineering
- Test-driven development
External links
- Design by contract @ Wikipedia