CWE
Home > CWE List > CWE- Individual Dictionary Definition (1.1)  
Search by ID:

CWE-586: Explicit Call to Finalize()

Individual Definition in a New Window
Explicit Call to Finalize()
Status: Draft
Weakness ID: 586 (Weakness Variant)
Description
Summary

The software makes an explicit call to the finalize() method from outside the finalizer.

Potential Mitigations

Do not make explicit calls to finalize(). Use static analysis tools to spot such instances.

Demonstrative Examples

The following code fragment calls finalize() explicitly:

// time to clean up
widget.finalize();
Other Notes

While the Java Language Specification allows an object's finalize() method to be called from outside the finalizer, doing so is usually a bad idea. For example, calling finalize() explicitly means that finalize() will be called more than once: the first time will be the explicit call and the last time will be the call that is made after the object is garbage collected.

Relationships
NatureTypeIDNameView(s) this relationship pertains toView(s)
ChildOfWeakness ClassWeakness ClassWeakness Class398Indicator of Poor Code Quality
Development Concepts (primary)699
ChildOfWeakness ClassWeakness ClassWeakness Class227Failure to Fulfill API Contract (aka 'API Abuse')
Research Concepts (primary)1000
PeerOfWeakness ClassWeakness ClassWeakness Class675Duplicate Operations on Resource
Research Concepts1000
Applicable Platforms
Languages
Java
Time of Introduction
* Implementation
Content History
Modifications
Eric Dalci. Cigital. 2008-07-01. (External)
updated Name, Potential_Mitigations, Time_of_Introduction
CWE Content Team. MITRE. 2008-09-08. (Internal)
updated Relationships, Other_Notes
Previous Entry Names
* Explicit Call to Finalize (changed 2008-09-09)
Page Last Updated: November 24, 2008