Open Access Te Herenga Waka-Victoria University of Wellington
Browse

FHJ: A formal model for hierarchical dispatching and overriding

conference contribution
posted on 2020-11-01, 22:21 authored by Y Wang, H Zhang, BCDS Oliveira, Marco ServettoMarco Servetto
© Yanlin Wang, Haoyuan Zhang, Bruno C. d. S. Oliveira, and Marco Servetto. Multiple inheritance is a valuable feature for Object-Oriented Programming. However, it is also tricky to get right, as illustrated by the extensive literature on the topic. A key issue is the ambiguity arising from inheriting multiple parents, which can have conflicting methods. Numerous existing work provides solutions for conflicts which arise from diamond inheritance: i.e. conflicts that arise from implementations sharing a common ancestor. However, most mechanisms are inadequate to deal with unintentional method conflicts: conflicts which arise from two unrelated methods that happen to share the same name and signature. This paper presents a new model called Featherweight Hierarchical Java (FHJ) that deals with unintentional method conflicts. In our new model, which is partly inspired by C++, conflicting methods arising from unrelated methods can coexist in the same class, and hierarchical dispatching supports unambiguous lookups in the presence of such conflicting methods. To avoid ambiguity, hierarchical information is employed in method dispatching, which uses a combination of static and dynamic type information to choose the implementation of a method at run-time. Furthermore, unlike all existing inheritance models, our model supports hierarchical method overriding: that is, methods can be independently overridden along the multiple inheritance hierarchy. We give illustrative examples of our language and features and formalize FHJ as a minimal Featherweight-Java style calculus.

History

Preferred citation

Wang, Y., Zhang, H., Oliveira, B. C. D. S. & Servetto, M. (2018, July). FHJ: A formal model for hierarchical dispatching and overriding. In Leibniz International Proceedings in Informatics, LIPIcs (109 ). https://doi.org/10.4230/LIPIcs.ECOOP.2018.20

Title of proceedings

Leibniz International Proceedings in Informatics, LIPIcs

Volume

109

Publication or Presentation Year

2018-07-01

Publication status

Published

ISSN

1868-8969

Usage metrics

    Conference papers

    Categories

    No categories selected

    Licence

    Exports

    RefWorks
    BibTeX
    Ref. manager
    Endnote
    DataCite
    NLM
    DC