Zero-Overhead Metaprogramming Reflection And Metaobject Protocols Fast And Without Compromises

PLDI '15: ACM SIGPLAN Conference on Programming Language Design and Implementation Portland OR USA June, 2015(2015)

引用 36|浏览74
暂无评分
摘要
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.
更多
查看译文
关键词
Metaprogramming,Reflection,Proxies,Metaobject Protocols,Meta-tracing,Partial Evaluation,Virtual Machines,Just-in-Time Compilation
AI 理解论文
溯源树
样例
生成溯源树,研究论文发展脉络
Chat Paper
正在生成论文摘要