Partilhar via


CA2104: Não declarar os tipos de referência mutáveis somente leitura

TypeName

DoNotDeclareReadOnlyMutableReferenceTypes

CheckId

CA2104

<strong>Categoria</strong>

Microsoft.Security

Alteração significativa

Não-separável

Causa

Um tipo visível externamente contém um campo visível externamente de somente leitura que é um tipo de referência mutáveis.

Descrição da regra

Um tipo de mutável é um tipo de dados cujos instância podem ser modificados. O System.Text.StringBuilder classe é um exemplo de um tipo de referência mutável. Ele contém membros que podem alterar o valor de uma instância da classe. Um exemplo de um tipo de referência imutável é o System.String classe. Depois que tiver sido instanciado, seu valor nunca pode alterar.

O modificador de somente leitura (ReadOnly (referência de C#) em C#, ReadOnly (Visual Basic) na Visual Basic, e const (C++) em C++) em uma referência (o ponteiro em C++) de campo de tipo impede o campo que está sendo substituído por uma instância diferente do tipo de referência. No entanto, o modificador não impede que os dados de instância do campo que está sendo modificado por meio do tipo de referência.

Campos de matriz de somente leitura estão isentos desta regra, mas em vez disso, causar uma violação da CA2105: Campos de matriz não devem ser lidos apenas regra.

Como corrigir violações

Para corrigir uma violação desta regra, remover o modificador de somente leitura ou se uma alteração significativa é aceitável, substitua o campo com um tipo imutável.

Quando suprimir avisos

É seguro eliminar um aviso esta regra se o tipo de campo é imutável.

Exemplo

O exemplo a seguir mostra uma declaração de campo que faz com que uma violação desta regra.

Imports System
Imports System.Text

Namespace SecurityLibrary

    Public Class MutableReferenceTypes

        Shared Protected ReadOnly SomeStringBuilder As StringBuilder

        Shared Sub New()
            SomeStringBuilder = New StringBuilder()
        End Sub

    End Class

End Namespace
using System;
using System.Text;

namespace SecurityLibrary
{
    public class MutableReferenceTypes
    {
        static protected readonly StringBuilder SomeStringBuilder;

        static MutableReferenceTypes()
        {
            SomeStringBuilder = new StringBuilder();
        }
    }
}
using namespace System;
using namespace System::Text;

namespace SecurityLibrary
{
    public ref class MutableReferenceTypes
    {
    protected:
        static StringBuilder^ const SomeStringBuilder = 
           gcnew StringBuilder();

    private:
        static MutableReferenceTypes()
        {
        }
    };
}