Marea: An Efficient Application-Level Object Graph Swapper

Abstract : Abstract During the execution of object-oriented applications, several millions of objects are created, used and then collected if they are not referenced. Prob- lems appear when objects are unused but cannot be garbage-collected because they are still referenced from other objects. This is an issue because those ob- jects waste primary memory and applications use more primary memory than they actually need. We claim that relying on the operating system's (OS) virtual memory is not always enough since it cannot take into account the domain and structure of applications. At the same time, applications have no easy way to parametrize nor cooperate with memory management. In this paper, we present Marea, an efficient application-level object graph swapper for object-oriented programming languages. Its main goal is to offer the programmer a novel so- lution to handle application-level memory. Developers can instruct our system to release primary memory by swapping out unused yet referenced objects to secondary memory. Our approach has been qualitatively and quantitatively val- idated. Our experiments and benchmarks on real-world applications show that Marea can reduce the memory footprint between 23% and 36%.
Complete list of metadatas

Cited literature [26 references]  Display  Hide  Download

https://hal.inria.fr/hal-00781129
Contributor : Lse Lse <>
Submitted on : Friday, January 25, 2013 - 2:02:05 PM
Last modification on : Thursday, February 21, 2019 - 11:02:54 AM
Long-term archiving on : Saturday, April 1, 2017 - 10:18:13 AM

File

Marea-JOT-CameraReady.pdf
Files produced by the author(s)

Identifiers

Citation

Mariano Martinez Peck, Noury Bouraqadi, Marcus Denker, Stéphane Ducasse, Luc Fabresse. Marea: An Efficient Application-Level Object Graph Swapper. The Journal of Object Technology, Chair of Software Engineering, 2013, 12 (1), pp.2:1-30. ⟨10.5381/jot.2013.12.1.a2⟩. ⟨hal-00781129⟩

Share

Metrics

Record views

1106

Files downloads

416