Affiliation:
1. Ohio State University, Columbus, OH, USA
2. IBM T. J. Watson Research Center, Hawthorne, NY, USA
Abstract
Many opportunities for easy, big-win, program optimizations are missed by compilers. This is especially true in highly layered Java applications. Often at the heart of these missed optimization opportunities lie computations that, with great expense, produce data values that have little impact on the program's final output. Constructing a new date formatter to format every date, or populating a large set full of expensively constructed structures only to check its size: these involve costs that are out of line with the benefits gained. This disparity between the formation costs and accrued benefits of data structures is at the heart of much runtime bloat.
We introduce a run-time analysis to discover these
low-utility
data structures. The analysis employs dynamic thin slicing, which naturally associates costs with value flows rather than raw data flows. It constructs a model of the incremental, hop-to-hop, costs and benefits of each data structure. The analysis then identifies suspicious structures based on imbalances of its incremental costs and benefits. To decrease the memory requirements of slicing, we introduce
abstract dynamic thin slicing
, which performs thin slicing over bounded abstract domains. We have modified the IBM J9 commercial JVM to implement this approach.
We demonstrate two client analyses: one that finds objects that are expensive to construct but are not necessary for the forward execution, and second that pinpoints ultimately-dead values. We have successfully applied them to large-scale and long-running Java applications. We show that these analyses are effective at detecting operations that have unbalanced costs and benefits.
Publisher
Association for Computing Machinery (ACM)
Subject
Computer Graphics and Computer-Aided Design,Software
Cited by
23 articles.
订阅此论文施引文献
订阅此论文施引文献,注册后可以免费订阅5篇论文的施引文献,订阅后可以查看论文全部施引文献
1. JShrink: in-depth investigation into debloating modern Java applications;Proceedings of the 28th ACM Joint Meeting on European Software Engineering Conference and Symposium on the Foundations of Software Engineering;2020-11-07
2. How Are Performance Issues Caused and Resolved?-An Empirical Study from a Design Perspective;Proceedings of the ACM/SPEC International Conference on Performance Engineering;2020-04-20
3. Butterfly Space: An Architectural Approach for Investigating Performance Issues;2020 IEEE International Conference on Software Architecture (ICSA);2020-03
4. Actionable Program Analyses for Improving Software Performance;Ernst Denert Award for Software Engineering 2019;2020
5. Darwinian data structure selection;Proceedings of the 2018 26th ACM Joint Meeting on European Software Engineering Conference and Symposium on the Foundations of Software Engineering;2018-10-26