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.