Zero-Overhead Metaprogramming: Reflection and Metaobject Protocols Fast and without Compromises

Stefan Marr, Chris Seaton, Stéphane Ducasse

Research output: Chapter in Book/Report/Conference proceedingConference proceedingspeer-review

Abstract

Runtime metaprogramming enables many useful applications and is often a convenient solution to solve problems in a generic way, which makes it widely used in frameworks, middleware, and domain-specific languages. However, powerful metaobject protocols are rarely supported and even common concepts such as reflective method invocation or dynamic proxies are not optimized. Solutions proposed in literature either restrict the metaprogramming capabilities or require application or library developers to apply performance improving techniques.

For overhead-free runtime metaprogramming, we demonstrate that dispatch chains, a generalized form of polymorphic inline caches common to self-optimizing interpreters, are a simple optimization at the language-implementation level. Our evaluation with self-optimizing interpreters shows that unrestricted metaobject protocols can be realized for the first time without runtime overhead, and that this optimization is applicable for just-in-time compilation of interpreters based on meta-tracing as well as partial evaluation. In this context, we also demonstrate that optimizing common reflective operations can lead to significant performance improvements for existing applications.
Original languageEnglish
Title of host publicationProceedings of the 36th ACM SIGPLAN Conference on Programming Language Design and Implementation
Pages545-554
Number of pages10
DOIs
Publication statusPublished - 2015
Externally publishedYes

Publication series

NamePLDI

Fields of science

  • 102 Computer Sciences

Cite this