Back to Search Start Over

MultiJava: design rationale, compiler implementation, and applications

Authors :
Clifton, Curtis
Millstein, Todd
Leavens, Gary T.
Chambers, Craig
Source :
ACM Transactions on Programming Languages & Systems. May, 2006, Vol. 28 Issue 3, p517, 59 p.
Publication Year :
2006

Abstract

MultiJava is a conservative extension of the Java programming language that adds symmetric multiple dispatch and open classes. Among other benefits, multiple dispatch provides a solution to the binary method problem. Open classes provide a solution to the extensibility problem of object-oriented programming languages, allowing the modular addition of both new types and new operations to an existing type hierarchy. This article illustrates and motivates the design of MultiJava and describes its modular static typechecking and modular compilation strategies. Although MultiJava extends Java, the key ideas of the language design are applicable to other object-oriented languages, such as C# and C++, and even, with some modifications, to functional languages such as ML. This article also discusses the variety of application domains in which MultiJava has been successfully used by others, including pervasive computing, graphical user interfaces, and compilers. MultiJava allows users to express desired programming idioms in a way that is declarative and supports static typechecking, in contrast to the tedious and type-unsafe workarounds required in Java. MultiJava also provides opportunities for new kinds of extensibility that are not easily available in Java. Categories and Subject Descriptors: D.1.5 [Programming Techniques]: Object-oriented Programming; D.3.2 [Programming Languages]: Language Classifications--Object-oriented languages; D.3.3 [Programming Languages]: Language Constructs and Features--Abstract data types, classes and objects, control structures, inheritance, modules, packages, patterns, procedures, functions, and subroutines; D.3.4 [Programming Languages]: Processors--Compilers; D.3.m [Programming Languages]: Miscellaneous General Terms: Languages, Design Additional Key Words and Phrases: Open classes, open objects, extensible classes, extensible external methods, external methods, multimethods, method families, generic functions, object-oriented programming languages, single dispatch, multiple dispatch, encapsulation, modularity, static typechecking, subtyping, inheritance, Java language, MultiJava language, separate compilation, expression problem, binary method problem, augmenting method problem

Details

Language :
English
ISSN :
01640925
Volume :
28
Issue :
3
Database :
Gale General OneFile
Journal :
ACM Transactions on Programming Languages & Systems
Publication Type :
Academic Journal
Accession number :
edsgcl.147477096