Polymorphism for Imperative Languages without Imperative Types

dc.contributor.authorWright, Andrew
dc.date.accessioned2017-08-02T22:03:19Z
dc.date.available2017-08-02T22:03:19Z
dc.date.issued1993-02-18
dc.date.noteFebruary 18, 1993
dc.description.abstractThe simple and elegant Hindley/Milner polymorphic type discipline is the basis of the type system of Standard ML, but ML's imperative features are a blight on this otherwise clean landscape. Polymorphism and imperative features cannot freely coexist without compromising type safety, hence Standard MLassigns imperative types of limited polymorphism to procedures that use references, exceptions, or continuations. Several other solutions exist, but all introduce new kinds of types that complicate the type system, contaminate module signatures, and violate abstraction by revealing the pure or imperative nature of a procedure in its type. We propose a seemingly radical alternative: by restricting polymorphism to values, imperative procedures have the same types as their behaviorally equivalent functional counterparts. Although the resulting type system does not accept all expressions typable in the purely functional sublanguage, this limitation is seldom encountered in practice. The vast majority of ML code already satisfies the restriction of polymorphism to values, and simple syntactic modifications fix the few non-conforming programs.
dc.format.extent10 pp
dc.identifier.citationWright, Andrew. "Polymorphism for Imperative Languages without Imperative Types." (1993) https://hdl.handle.net/1911/96432.
dc.identifier.digitalTR93-200
dc.identifier.urihttps://hdl.handle.net/1911/96432
dc.language.isoeng
dc.rightsYou are granted permission for the noncommercial reproduction, distribution, display, and performance of this technical report in any format, but this permission is only for a period of forty-five (45) days from the most recent time that you verified that this technical report is still available from the Computer Science Department of Rice University under terms that include this permission. All other rights are reserved by the author(s).
dc.titlePolymorphism for Imperative Languages without Imperative Types
dc.typeTechnical report
dc.type.dcmiText
Files
Original bundle
Now showing 1 - 1 of 1
Loading...
Thumbnail Image
Name:
TR93-200.pdf
Size:
6.61 MB
Format:
Adobe Portable Document Format