Compartilhar via


Design de campo

Observação

Este conteúdo é reimpresso com permissão da Pearson Education, Inc. de Framework Design Guidelines: Conventions, Idioms, and Patterns for Reusable .NET Libraries, 2nd Edition. Essa edição foi publicada em 2008 e, desde então, o livro foi totalmente revisado na terceira edição. Algumas das informações nesta página podem estar desatualizadas.

O princípio do encapsulamento é uma das noções mais importantes no design orientado a objeto. Esse princípio afirma que os dados armazenados dentro de um objeto devem ser acessíveis somente para esse objeto.

Uma maneira útil de interpretar o princípio é dizer que um tipo deve ser criado para que as alterações em campos desse tipo (alterações de nome ou tipo) possam ser feitas sem quebrar o código que não seja para os membros do tipo. Essa interpretação imediatamente implica que todos os campos devem ser privados.

Excluímos campos constantes e estáticos somente leitura dessa restrição estrita, pois esses campos, praticamente por definição, nunca são necessários para serem alterados.

❌ NÃO forneça campos de instância públicos ou protegidos.

Você deve fornecer propriedades para acessar campos em vez de torná-los públicos ou protegidos.

✔️ USE campos constantes para constantes que nunca serão alteradas.

O compilador queima os valores dos campos const diretamente no código de chamada. Portanto, os valores const nunca podem ser alterados sem o risco de quebrar a compatibilidade.

✔️ USE campos estáticos públicos readonly para instâncias de objeto predefinidas.

Se houver instâncias predefinidas do tipo, declare-as como campos estáticos públicos somente leitura do próprio tipo.

❌ NÃO atribua instâncias de tipos mutáveis a campos readonly.

Um tipo mutável é um tipo com instâncias que podem ser modificadas depois de instanciadas. Por exemplo, as matrizes, a maioria das coleções e os fluxos são tipos mutáveis, mas System.Int32, System.Uri e System.String são todos imutáveis. O modificador somente leitura em um campo de tipo de referência impede que a instância armazenada no campo seja substituída, mas não impede que os dados da instância do campo sejam modificados chamando membros que alteram a instância.

Portions © 2005, 2009 Microsoft Corporation. Todos os direitos reservados.

Reimpresso com permissão da Pearson Education, Inc. das Diretrizes de Design do Framework: convenções, linguagens e padrões para bibliotecas do .NET reutilizável, 2ª edição por Krzysztof Cwalina e Brad Abrams, publicado em 22 de outubro de 2008 por Addison-Wesley Professional como parte da série de desenvolvimento do Microsoft Windows.

Confira também