Abstract
Representation independence formally characterizes the encapsulation provided by language constructs for data abstraction and justifies reasoning by simulation. Representation independence has been shown for a variety of languages and constructs but not for shared references to mutable state; indeed it fails in general for such languages. This article formulates representation independence for classes, in an imperative, object-oriented language with pointers, subclassing and dynamic dispatch, class oriented visibility control, recursive types and methods, and a simple form of module. An instance of a class is considered to implement an abstraction using private fields and so-called representation objects. Encapsulation of representation objects is expressed by arestriction, called confinement, on aliasing. Representation independence is proved for programs satisfying the confinement condition. A static analysis is given for confinement that accepts common designs such as the observer and factory patterns. The formalization takes into account not only the usual interface between a client and a class that provides an abstraction but also the interface (often called "protected") between the class and its subclasses.
| Original language | English |
|---|---|
| Pages (from-to) | 894-960 |
| Number of pages | 67 |
| Journal | Journal of the ACM |
| Volume | 52 |
| Issue number | 6 |
| DOIs | |
| State | Published - 2005 |
Keywords
- Alias control
- Confinement
- Data refinement
- Relational parametricity
- Simulation
Fingerprint
Dive into the research topics of 'Ownership confinement ensures representation independence for object-oriented programs'. Together they form a unique fingerprint.Cite this
- APA
- Author
- BIBTEX
- Harvard
- Standard
- RIS
- Vancouver