CA1821: Os finalizadores vazios remover
TypeName |
RemoveEmptyFinalizers |
CheckId |
CA1821 |
<strong>Categoria</strong> |
Microsoft.Performance |
Alteração significativa |
Não-separável |
Causa
Um tipo implementa um finalizador que está vazia, chama somente o finalizador do tipo base ou chama somente condicionalmente emitida métodos.
Descrição da regra
Sempre que possível, evite finalizadores causa da sobrecarga de desempenho adicional envolvido na vida útil do objeto de controle.O coletor de lixo executará o finalizador antes que ela coleta o objeto.Isso significa que duas coleções será solicitadas a coletar o objeto.Um finalizador vazio incorre isso maior sobrecarga, sem qualquer benefício.
Como corrigir violações
Remova o finalizador vazio.Se um finalizador for necessário para depuração, coloque o finalizador todo #if DEBUG / #endif diretivas.
Quando suprimir avisos
Não suprimir uma mensagem a partir desta regra.Falha para suprimir a finalização diminui o desempenho e não fornece nenhuma benefícios.
Exemplo
O exemplo a seguir mostra um finalizador vazio que deve ser removido, um finalizador que deve ser colocado entre #if DEBUG / #endif diretivas e um finalizador que usa a #if DEBUG / #endif diretivas corretamente.
using System.Diagnostics;
public class Class1
{
// Violation occurs because the finalizer is empty.
~Class1()
{
}
}
public class Class2
{
// Violation occurs because Debug.Fail is a conditional method.
// The finalizer will contain code only if the DEBUG directive
// symbol is present at compile time. When the DEBUG
// directive is not present, the finalizer will still exist, but
// it will be empty.
~Class2()
{
Debug.Fail("Finalizer called!");
}
}
public class Class3
{
#if DEBUG
// Violation will not occur because the finalizer will exist and
// contain code when the DEBUG directive is present. When the
// DEBUG directive is not present, the finalizer will not exist,
// and therefore not be empty.
~Class3()
{
Debug.Fail("Finalizer called!");
}
#endif
}