Jump to content

Dispose pattern

From Wikipedia, the free encyclopedia

This is an old revision of this page, as edited by Forderud (talk | contribs) at 15:59, 30 January 2013 (Language constructs: add Java "try-with-resources" reference link). The present address (URL) is a permanent link to this revision, which may differ significantly from the current revision.

In computer programming, the dispose pattern is a design pattern which is used to handle resource cleanup in runtime environments that use automatic garbage collection. The fundamental problem that the dispose pattern aims to solve is that, because objects in a garbage-collected environment have finalizers rather than destructors, there is no guarantee that an object will be destroyed at any deterministic point in time. The dispose pattern works around this by giving an object a method (usually called Dispose or similar) which frees any resources the object is holding onto.

Many garbage-collected languages offer language constructs to avoid having to call the dispose method explicitly in many situations. These language constructs leads to results similar to what is obtained with the Resource Acquisition Is Initialization (RAII) idiom in languages with deterministic memory management (like e.g. C++).

Motivation

It is very common to write code similar to the listing below when using resources that might throw exceptions in garbage-collected languages:

Resource resource = null;
try {
    resource = getResource(); // Attempt to acquire the resource.
    // Perform actions with the resource.
    ...
} finally {
    if (resource != null) // Resource might not been acquired, or already freed
        resource.Dispose();
}

The try...finally construct is necessary for proper exception safety, since the finally block enables execution of cleanup logic regardless of if an exception is thrown or not in the try block.

One disadvantage of this approach is that it requires the programmer to explicitly add cleanup code in a finally block. This leads to code size bloat, and failure to do so will lead to resource leakage in the program.

Language constructs

To make the dispose pattern less verbose, several languages have some kind of built-in support for it:

The C# language features the using statement [1] that automatically calls the Dispose method on an object that implements the IDisposable interface:

using (Resource resource = GetResource())
{
    // Perform actions with the resource.
    ...
}

which is equal to:

Resource resource = GetResource()
try 
{
    // Perform actions with the resource.
    ...
}
finally 
{
    if (resource != null) // Resource might not been acquired, or already freed
        ((IDisposable)resource).Dispose(); 
}

Similarly, the Python language has a with statement can be used to similar effect:

with get_resource() as resource:
    # Perform actions with the resource.
    ...

The Java language introduced a new syntax called try-with-resources in Java version 7 [2]. It can be used on objects that implement the AutoCloseable interface (that defines method close()):

try ( OutputStream x = new OutputStream(...) ){
    //do something with x
} catch(IOException ex){
    //handle exception
} //The resource x is automatically closed

See also

References

  1. ^ Microsoft MSDN: using Statement (C# Reference)
  2. ^ Oracle Java tutorial: The try-with-resources Statement