Instrução Set (Visual Basic)
Declara um procedimento de propriedade Set usado para atribuir um valor a uma propriedade.
[ <attributelist> ] [ accessmodifier ] Set (ByVal value [ As datatype ])
[ statements ]
End Set
Partes
attributelist
Opcional. Veja Lista de Atributos.accessmodifier
Opcional, em no máximo uma, das declarações Get e Set nessa propriedade. Pode ser um dos seguintes:Consulte Níveis de acesso no Visual Basic.
value
Obrigatório. Parâmetro contendo o novo valor para a propriedade.datatype
Necessário se Option Strict estiver On. Tipo de dado do parâmetro value O tipo de dado especificado deve ser o mesmo do tipo de dado da propriedade onde essa declaração Set for declarada.statements
Opcional. Uma ou mais declarações que executam quando o procedimento de propriedade Set for chamado.End Set
Obrigatório. Finaliza a definição do procedimento de propriedade Set.
Comentários
Cada propriedade deve ter uma procedimento de propriedade Set a não ser que a propriedade seja marcada como ReadOnly. O procedimento Set é usado para determinar o valor da propriedade.
Visual Basic chama automaticamente um procedimento Set de propriedade quando uma declaração de atribuição fornece um valor para ser armazenado na propriedade.
Visual Basic passa um parâmetro para o procedimento Set durante atribuições de propriedade. Se não for fornecido um parâmetro para Set, o ambiente de desenvolvimento integrado (IDE) usa uma parâmetro implícito de nome value. O parâmetro armazena o valor a ser atribuído à propriedade. Você, normalmente, armazena esse valor em uma variável local privada e o retorna quando o procedimento Get for chamado.
O corpo da declaração de propriedade pode conter somente os procedimentos Get e Set de propriedade entre Instrução Property e a declaração End Property. Não é possível armazenar nada além desses procedimentos. Em particular, não é possível armazenar o valor atual da propriedade. Você deve armazenar esse valor fora da propriedade, pois se armazenar no interior de um dos procedimentos de propriedade, o outro procedimento de propriedade não poderá acessá-lo. A abordagem usual é armazenar o valor em uma variável Particular (Visual Basic) declarada no mesmo nível da propriedade. Você deve definir um procedimento Set no interior da propriedade para o qual se aplica.
O procedimento Set tem como padrão o nível de acesso da propriedade que o contém, a não ser que você usa accessmodifier na declaração Set.
Regras
Níveis de Acesso Mistos. Se você estiver definindo uma propriedade de leitura-gravação, opcionalmente, você pode especificar um nível de acesso diferente para cada uma a Get ou o Set procedimento, mas não ambos. Se isso for feito, o nível de acesso do procedimento deve ser mais restritivo que o nível de acesso da propriedade. Por exemplo, se a propriedade for declarada como Friend, você pode declarar o procedimento Set como Private, mas não como Public.
Se você estiver definindo uma propriedade WriteOnly, o procedimento Set representa a propriedade completa. Você não pode declarar um nível de acesso diferente para Set, pois isso configuraria dois níveis de acesso para a propriedade.
Comportamento
Retornando a partir de um Procedimento de Propriedade. Quando o Set procedimento retorna para o código de chamada, a execução continua após a instrução que forneceu o valor a ser armazenado.
Os procedimentos de propriedade Set podem retornar utilizando-se Instrução Return (Visual Basic) ou Instrução Exit (Visual Basic).
As declarações Exit Property e Return causam uma saída imediata do procedimento de propriedade. Qualquer número de declarações Exit Property e Return pode aparecer em qualquer lugar no procedimento, e você pode misturar declarações Exit Property e Return.
Exemplo
O exemplo a seguir usa a declaração Set para configurar o valor de uma propriedade.
Class propClass
Private propVal As Integer
Property prop1() As Integer
Get
Return propVal
End Get
Set(ByVal value As Integer)
propVal = value
End Set
End Property
End Class