CA2015: Do not define finalizers for types derived from MemoryManager (code analysis) - .NET (original) (raw)
Property | Value |
---|---|
Rule ID | CA2015 |
Title | Do not define finalizers for types derived from MemoryManager |
Category | Reliability |
Fix is breaking or non-breaking | Non-breaking |
Enabled by default in .NET 9 | As warning |
Cause
Defining finalizers for types derived from MemoryManager
Rule description
Adding a finalizer to a type derived from MemoryManager is likely an indication of a bug, as it suggests a native resource that could have been handed out in a Span is getting cleaned up and potentially while it is still in use by the Span.
Note
The MemoryManager class is intended for advanced scenarios. Most developers do not need to use it.
How to fix violations
To fix the violation, remove the finalizer definition.
class DerivedClass <T> : MemoryManager<T>
{
public override bool Dispose(bool disposing)
{
if (disposing)
{
_handle.Dispose();
}
}
...
// Violation occurs, remove the finalizer to fix the warning.
~DerivedClass() => Dispose(false);
}
When to suppress warnings
It is safe to suppress a violation of this rule if the intent is to create a finalizer for debugging or validation purposes.
Suppress a warning
If you just want to suppress a single violation, add preprocessor directives to your source file to disable and then re-enable the rule.
#pragma warning disable CA2015
// The code that's violating the rule is on this line.
#pragma warning restore CA2015
To disable the rule for a file, folder, or project, set its severity to none
in the configuration file.
[*.{cs,vb}]
dotnet_diagnostic.CA2015.severity = none
To disable this entire category of rules, set the severity for the category to none
in the configuration file.
[*.{cs,vb}]
dotnet_analyzer_diagnostic.category-Reliability.severity = none
For more information, see How to suppress code analysis warnings.