TY - JOUR
T1 - Older-first garbage collection in practice
T2 - Evaluation in a Java virtual machine
AU - Stefanović, Darko
AU - Hertz, Matthew
AU - Blackburn, Stephen M.
AU - McKinley, Kathryn S.
AU - Moss, J. Eliot B.
PY - 2003/2
Y1 - 2003/2
N2 - Until recently, the best performing copying garbage collectors used a generational policy which repeatedly collects the very youngest objects, copies any survivors to an older space, and then infrequently collects the older space. A previous study that used garbage-collection simulation pointed to potential improvements by using an Older-First copying garbage collection algorithm. The Older-First algorithm sweeps a fixed-sized window through the heap from older to younger objects, and avoids copying the very youngest objects which have not yet had sufficient time to die. We describe and examine here an implementation of the Older-First algorithm in the Jikes RVM for Java. This investigation shows that Older-First can perform as well as the simulation results suggested, and greatly improves total program performance when compared to using a fixed- the nursery generation collector. We further compare Older-First to a flexible-size nursery generational collector in which the nursery occupies all of the heap that does not contain older objects. In these comparisons, the flexible-nursery collector is occasionally the better of the two, but on average the Older-First collector performs the best.
AB - Until recently, the best performing copying garbage collectors used a generational policy which repeatedly collects the very youngest objects, copies any survivors to an older space, and then infrequently collects the older space. A previous study that used garbage-collection simulation pointed to potential improvements by using an Older-First copying garbage collection algorithm. The Older-First algorithm sweeps a fixed-sized window through the heap from older to younger objects, and avoids copying the very youngest objects which have not yet had sufficient time to die. We describe and examine here an implementation of the Older-First algorithm in the Jikes RVM for Java. This investigation shows that Older-First can perform as well as the simulation results suggested, and greatly improves total program performance when compared to using a fixed- the nursery generation collector. We further compare Older-First to a flexible-size nursery generational collector in which the nursery occupies all of the heap that does not contain older objects. In these comparisons, the flexible-nursery collector is occasionally the better of the two, but on average the Older-First collector performs the best.
UR - http://www.scopus.com/inward/record.url?scp=1442265475&partnerID=8YFLogxK
U2 - 10.1145/773039.773042
DO - 10.1145/773039.773042
M3 - Article
AN - SCOPUS:1442265475
SN - 0362-1340
VL - 38
SP - 25
EP - 36
JO - ACM SIGPLAN Notices
JF - ACM SIGPLAN Notices
IS - 2 SUPPL.
ER -