Go with the flow: Profiling copies to find runtime bloat
Guoqing Xu, Matthew Arnold, et al.
PLDI 2009
Virtual machines face significant performance challenges beyond those confronted by traditional static optimizers. First, portable program representations and dynamic language features, such as dynamic class loading, force the deferral of most optimizations until runtime, inducing runtime optimization overhead. Second, modular program representations preclude many forms of whole-program interprocedural optimization. Third, virtual machines incur additional costs for runtime services such as security guarantees and automatic memory management. To address these challenges, vendors have invested considerable resources into adaptive optimization systems in production virtual machines. Today, mainstream virtual machine implementations include substantial infrastructure for online monitoring and profiling, runtime compilation, and feedback-directed optimization. As a result, adaptive optimization has begun to mature as a widespread production-level technology. This paper surveys the evolution and current state of adaptive optimization technology in virtual machines. © 2005 IEEE.
Guoqing Xu, Matthew Arnold, et al.
PLDI 2009
Matthew Arnold, Adam Welc, et al.
OOPSLA 2005
Christoph Bockisch, Matthew Arnold, et al.
ACM SIGPLAN Notices
Sara S. Hamouda, Benjamin Herta, et al.
X10 2016