Alphard is a design for a programming system that supports the abstraction and verification techniques required by modern program'ming methodology. During the language design process, we were concerned simultaneously with problems of methodology, correctness, and efficiency. Methodological concerns are addressed through facilities for defining new, taskAmspecific abstractions that capture complex notions in terms of their intended properties, without explicating them in terms of specific lowAm level implementations. Techniques for verifying certain properties of these programs address the correctness concerns. Finally, the language has been designed to permit compilation to efficient object code. Although a compiler was not implemented, the research shed light on specification issues and on programming methodology. an abstraction, specifying its behavior Alphard language constructs allow a programmer to isolate publicly while localizing knowledge about its implementation. The verification of such an abstraction consists of showing that its implementation behaves in accordance with the public specification. Given such a verification, the abstraction may be used with confidence to construct higherAmlevel, more abstract, programs. The most common kind of abstraction in Alphard corresponds to what is now called an abstract data type. An abstract data type comprises a set of values for elements of the type and a set of operations on those values. A new language construct, the form, provides a way to encapsulate the definitions of data structures and operations in such a way that only public information could be accessed by the rest of the program.User Manual and Report, SpringerVerlag Lecture Notes in Computer Science, No. ... [London?6] Ralph L. London, Mary Shaw, and Wm. A. Wulf, aquot;Abstraction and Verification in Alphard: A Symbol Table Exampleaquot;, Carnegie-Mellon Universityanbsp;...
|Title||:||Alphard: Form and Content|
|Publisher||:||Springer Science & Business Media - 2012-12-06|