We compare two different facilities for running cleanup actions for objects that are about to reach the end of their life.Destructors, such as we find in C++, are invoked synchronously when an object goes out of scope. They make it easier to implement cleanup actions for objects of well-known lifetime, especially in the presence of exceptions.Languages like Java[8], Modula-3[12], and C\#[6] provide a different kind of "finalization" facility: Cleanup methods may be run when the garbage collector discovers a heap object to be otherwise inaccessible. Unlike C++ destructors, such methods run in a separate thread at some much less well-defined time.Languages like Java[8], Modula-3[12], and C\#[6] provide a different kind of "finalization" facility: Cleanup methods may be run when the garbage collector discovers a heap object to be otherwise inaccessible. Unlike C++ destructors, such methods run in a separate thread at some much less well-defined time.We argue that these are fundamentally different, and potentially complementary, language facilities. We also try to resolve some common misunderstandings about finalization in the process. In particular: The asynchronous nature of finalizers is not just an accident of implementation or a shortcoming of tracing collectors; it is necessary for correctness of client code, fundamentally affects how finalizers must be written, and how finalization facilities should be presented to the user. An object may legitimately be finalized while one of its methods are still running. This should and can be addressed by the language specification amd client code.
[1]
Joshua J. Bloch.
Effective Java : programming language guide
,
2001
.
[2]
Greg Nelson,et al.
Systems programming in modula-3
,
1991
.
[3]
Bill Kalsow,et al.
Some Useful Modula-3 Interfaces
,
1996
.
[4]
James Gosling.
The Java Language Specification - Second Edition
,
2000
.
[5]
Barry Hayes.
Finalization in the Collector Interface
,
1992,
IWMM.
[6]
R. Kent Dybvig,et al.
Guardians in a generation-based garbage collector
,
1993,
PLDI '93.
[7]
G. vanRossum.
Python reference manual
,
1995
.
[8]
Guy L. Steele,et al.
The Java Language Specification
,
1996
.
[9]
Hans-Juergen Boehm,et al.
Ropes: An alternative to strings
,
1995,
Softw. Pract. Exp..
[10]
John R. Ellis,et al.
Safe, Efficient Garbage Collection for C++
,
1994,
C++ Conference.
[11]
Bjarne Stroustrup,et al.
The Design and Evolution of C
,
1994
.
[12]
J. Davenport.
Editor
,
1960
.