CA2015: Non definire finalizzatori per i tipi derivati da MemoryManager<T>

Valore
ID regola CA2015
Categoria Affidabilità
Correzione che causa un'interruzione o una mancata interruzione Non di rilievo

Causa

Definizione dei finalizzatori per i tipi derivati da MemoryManager<T>

Descrizione della regola

L'aggiunta di un finalizzatore a un tipo derivato da MemoryManager<T> è probabilmente un'indicazione di un bug, perché suggerisce che una risorsa nativa che potrebbe essere stata distribuita in un Span<T> oggetto viene pulita e potenzialmente mentre è ancora in uso da .Span<T>

Nota

La MemoryManager<T> classe è destinata a scenari avanzati. La maggior parte degli sviluppatori non deve usarla.

Come correggere le violazioni

Per correggere la violazione, rimuovere la definizione del finalizzatore.

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);
}

Quando eliminare gli avvisi

È possibile eliminare una violazione di questa regola se lo scopo è creare un finalizzatore a scopo di debug o convalida.

Eliminare un avviso

Se si vuole eliminare una singola violazione, aggiungere direttive del preprocessore al file di origine per disabilitare e quindi riabilitare la regola.

#pragma warning disable CA2015
// The code that's violating the rule is on this line.
#pragma warning restore CA2015

Per disabilitare la regola per un file, una cartella o un progetto, impostarne la gravità none su nel file di configurazione.

[*.{cs,vb}]
dotnet_diagnostic.CA2015.severity = none

Per disabilitare questa intera categoria di regole, impostare la gravità per la categoria none su nel file di configurazione.

[*.{cs,vb}]
dotnet_analyzer_diagnostic.category-Reliability.severity = none

Per altre informazioni, vedere Come eliminare gli avvisi di analisi del codice.

Vedi anche