Polymorphism for Imperative Languages without Imperative Types

dc.contributor.authorWright, Andrewen_US
dc.date.accessioned2017-08-02T22:03:19Zen_US
dc.date.available2017-08-02T22:03:19Zen_US
dc.date.issued1993-02-18en_US
dc.date.noteFebruary 18, 1993en_US
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.en_US
dc.format.extent10 ppen_US
dc.identifier.citationWright, Andrew. "Polymorphism for Imperative Languages without Imperative Types." (1993) https://hdl.handle.net/1911/96432.en_US
dc.identifier.digitalTR93-200en_US
dc.identifier.urihttps://hdl.handle.net/1911/96432en_US
dc.language.isoengen_US
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).en_US
dc.titlePolymorphism for Imperative Languages without Imperative Typesen_US
dc.typeTechnical reporten_US
dc.type.dcmiTexten_US
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