Adjusted Objects: An Efficient and Principled Approach to Scalable Programming (Extended Version)
Adjusted Objects: An Efficient and Principled Approach to Scalable Programming (Extended Version)
Parallel programs require software support to coordinate access to shared data. For this purpose, modern programming languages provide strongly-consistent shared objects. To account for their many usages, these objects offer a large API. However, in practice, each program calls only a tiny fraction of the interface. Leveraging such an observation, we propose to tailor a shared object for a specific usage. We call this principle adjusted objects. Adjusted objects already exist in the wild. This paper provides their first systematic study. We explain how everyday programmers already adjust common shared objects (such as queues, maps, and counters) for better performance. We present the formal foundations of adjusted objects using a new tool to characterize scalability, the indistinguishability graph. Leveraging this study, we introduce a library named DEGO to inject adjusted objects in a Java program. In micro-benchmarks, objects from the DEGO library improve the performance of standard JDK shared objects by up to two orders of magnitude. We also evaluate DEGO with a Retwis-like benchmark modeled after a social network application. On a modern server-class machine, DEGO boosts by up to 1.7x the performance of the benchmark.
Boubacar Kane、Pierre Sutra
计算技术、计算机技术
Boubacar Kane,Pierre Sutra.Adjusted Objects: An Efficient and Principled Approach to Scalable Programming (Extended Version)[EB/OL].(2025-04-28)[2025-05-29].https://arxiv.org/abs/2504.19495.点此复制
评论