
![]() | ![]() |
13.2. Destroying an Object
13.2.1. Problem
You
want to run special code whenever an object is no longer used. This
is sometimes needed when the object is an interface to the outside
world—or contains circular data structures—and must clean
up after itself. You might remove temporary files, break circular
links, gracefully disconnect from a socket, or kill a spawned
subprocess.
13.2.2. Solution
Create a method named DESTROY. This will be
invoked when there are no more references to the object, or else when
the program shuts down, whichever comes first. You don't need to do
any memory deallocation here, just any finalization code that makes
sense for the class.sub DESTROY {
my $self = shift;
printf("$self dying at %s\n", scalar localtime);
}
13.2.3. Discussion
Every story has a beginning and an end. The beginning of the object's
story is its constructor, explicitly invoked when the object comes
into existence. The end of its story is the
destructor, a method implicitly invoked when an
object leaves this life. Any per-object clean-up code is placed in
the destructor, which must be named DESTROY.
Why can't destructors have
arbitrary names? Because although constructors are explicitly called
by name, the destructor is not. Destruction happens automatically via
Perl's garbage collection (GC) system, which is currently implemented
as a quick but lazy reference-based GC system. To know what to call,
Perl insists that the destructor be named DESTROY.
If more than one object goes out of scope at once, Perl makes no
promise about invoking destructors in any particular order.Why is DESTROY in all caps? Perl on occasion uses
purely uppercase function names as a convention to indicate that the
function will be automatically called by Perl. Others that are called
implicitly include BEGIN, INIT,
END, AUTOLOAD, plus all methods
used by tied objects (see Recipe 13.15), such
as STORE and FETCH.The user doesn't care when the destructor is invoked. It just happens
when it's supposed to. In languages without any form of GC, this is
undependable, so the programmer must explicitly invoke the destructor
to clean up memory and state, crossing their fingers that it's the
right time to do so. This is a terrible state of affairs.Because of Perl's automatic memory management, an object destructor
is rarely needed in Perl. Even when it is, explicit invocation is not
only uncalled for, it's downright dangerous. The destructor will be
invoked by the run-time system when the object is no longer in use.
Most classes don't need a destructor because Perl takes care of
simple matters like memory deallocation.The only situation where Perl's reference-based garbage collection
system won't work for you is when there's a circularity in your data
structure, such as:$self->{WHATEVER} = $self;
In that case, you must delete the self-reference manually if you
expect your program not to leak memory. While admittedly error-prone,
this is the best we can do right now. Recipe 11.5 and Recipe 13.13 provide
solutions to this problem using techniques easily generalizable to
any data structure. Nonetheless, rest assured that when your program
is finished, all objects' destructors are duly invoked. At
interpreter shutdown time, a second, more sweeping form of garbage
collection is performed. Not even unreachable or circular objects can
escape this final destruction. So you are guaranteed that an object
eventually gets properly destroyed, unless a
program never exits. If you're running Perl embedded in another
application, the second GC pass happens more
frequently—whenever an interpreter shuts down.DESTROY is not invoked when a
program replaces itself with another via exec.
13.2.4. See Also
perltoot(1), perlboot(1),
and perlobj(1); the section "Garbage Collection,
Circular References, and Weak References" in Chapter 8 of
Programming Perl; Recipe 13.11; Recipe 13.13
![]() | ![]() | ![]() |
13.1. Constructing an Object | ![]() | 13.3. Managing Instance Data |

Copyright © 2003 O'Reilly & Associates. All rights reserved.