Refatoração Encapsular Campo (C#)
O Campo encapsular operação de refatoração permite criar rapidamente uma propriedade de um campo existente e atualizar diretamente o seu código com referências a nova propriedade.
Quando um campo é pública, outros objetos têm acesso direto a esse campo e pode modificá-lo, sem ser detectado pelo objeto que é proprietária desse campo. Usando Propriedades para encapsular esse campo, você pode não permitir acesso direto aos campos.
Para criar a nova propriedade, o Campo encapsular operação altera o modificador de acesso para o campo que você deseja encapsular para particulare gera obter e Definir acessadores para aquele campo. Em alguns casos, apenas um get o acessador é gerado, como, por exemplo, quando o campo está declarado como somente leitura.
O mecanismo de refatoração atualiza o seu código com referências à nova propriedade nas áreas especificadas na Referências de atualização seção a Campo encapsular caixa de diálogo.
Para criar uma propriedade de um campo
Crie um aplicativo de console chamado EncapsulateFieldExamplee, em seguida, substitua Program com o seguinte exemplo de código.
class Square { // Select the word 'width' and then use Encapsulate Field. public int width, height; } class MainClass { public static void Main() { Square mySquare = new Square(); mySquare.width = 110; mySquare.height = 150; // Output values for width and height. Console.WriteLine("width = {0}", mySquare.width); Console.WriteLine("height = {0}", mySquare.height); } }
No O Editor de código, coloque o cursor na declaração, no nome do campo que você deseja encapsular. No exemplo abaixo, coloque o cursor na palavra width:
public int width, height;
Sobre o Refactor menu, clique em Encapsulate Field.
O Campo encapsular caixa de diálogo aparece.
Você também pode digitar o atalho de teclado CTRL + R, E para exibir o Campo encapsular caixa de diálogo.
Você também pode direito o cursor, aponte para Refactore, em seguida, clique em Encapsulate Field para exibir o Encapsular campo caixa de diálogo.
Especifique as configurações.
Pressione ENTER ou clique o OK botão.
Se você tiver selecionado a Visualizar alterações de referência opção, em seguida, a Visualizar alterações de referência janela é aberta. Clique no Aplicar botão.
O seguinte get e set código do acessador é exibido no seu arquivo de origem:
public int Width { get { return width; } set { width = value; } }
O código do Main método também é atualizado para o novo Width nome de propriedade.
Square mySquare = new Square(); mySquare.Width = 110; mySquare.height = 150; // Output values for width and height. Console.WriteLine("width = {0}", mySquare.Width);
Comentários
O Campo encapsular operação só é possível quando o cursor está posicionado na mesma linha como a declaração de campo.
Para declarações de declarar vários campos, Campo encapsular usa a vírgula como um limite entre campos e inicia a refatoração no campo que está mais próximo do cursor e na mesma linha como o cursor. Você também pode especificar qual campo você deseja encapsular, selecionando o nome do campo na declaração.
O código que é gerado por esta operação de refatoração é modelado pelo recurso de trechos de código de campo encapsulate. Code Snippets são modificáveis. Para obter mais informações, consulte Trechos de código.
Consulte também
Referência
Trechos de código do Visual C#