AppDomain.IsFinalizingForUnload Method
Definition
Important
Some information relates to prerelease product that may be substantially modified before it’s released. Microsoft makes no warranties, express or implied, with respect to the information provided here.
Indicates whether this application domain is unloading, and the objects it contains are being finalized by the common language runtime.
public:
bool IsFinalizingForUnload();
public bool IsFinalizingForUnload ();
member this.IsFinalizingForUnload : unit -> bool
Public Function IsFinalizingForUnload () As Boolean
Returns
true
if this application domain is unloading and the common language runtime has started invoking finalizers; otherwise, false
.
Remarks
The finalization method for an object provides you an opportunity to perform any necessary cleanup operations before the object is garbage collected. After finalization, the object is accessible but in an invalid state and therefore unusable. Eventually, garbage collection completes and reclaims the object.
An object's finalization method is called in one of the following situations: during garbage collection, when the common language runtime is shutting down, or when the application domain that contains the object is unloaded. The IsFinalizingForUnload method returns true
only in the last case; it does not return true
if finalization results from routine garbage collection or from CLR shutdown.
Note
To determine whether finalization is due to CLR shutdown, use the Environment.HasShutdownStarted property. It returns true
if finalization is due to an application domain being unloaded or to the CLR shutting down.
While executing in your finalization method during domain unloading, you might want to access another object that is referenced by a static field and has a finalization method. However, you cannot reliably do so because the accessed object might already have been finalized.
Note
An exception to this rule is the Console class, which contains static fields that reference stream objects, but is implemented specially so you can always write to the system console, even during domain unloading or system shutdown.
Use this method in an object's finalization method to determine whether the application domain that contains the object is unloading. If that is the case, you cannot reliably access any object that has a finalization method and is referenced by a static field.
Applies to
See also
.NET