CWE Database
/

CWE-586

Back to CWE list

CWE-586

Explicit Call to Finalize()

Base
Draft

Description

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

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.

Common Consequences

Scope

Integrity
Other

Impact

Unexpected State, Quality Degradation

Potential Mitigations

Implementation

Do not make explicit calls to finalize().

Applicable Platforms

Java

Security Training

Train your team to recognize and prevent security threats with our comprehensive security awareness program.

Start Training

Vulnerability Scanning

Discover vulnerabilities in your applications and infrastructure before attackers do.

Scan Now