Partilhar via


Estendendo o Namespace My no Visual Basic

O namespace My em Visual Basic expõe propriedades e métodos que permitem que você facilmente aproveite o poder do .NET Framework.O namespace My simplifica problemas comuns de programação, reduzindo frequentemente uma tarefa difícil para uma única linha de código.Além disso, o namespace My é totalmente extensível para que você pode personalizar o comportamento de My e adicionar novos serviços para sua hierarquia para adaptar-se às necessidades de aplicativos específicos.Este tópico aborda como personalizar membros existentes do namespace My e como adicionar suas próprias classes personalizadas ao namespace My.

Conteúdo do Tópico

  • Personalizando membros existentes do Namespace My

  • Adicionando membros a meus objetos

  • Adicionando objetos personalizados para o Namespace My

  • Adicionando membros para o My Namespace

  • Adicionar eventos a objetos My personalizados

  • Diretrizes de Design

  • Projetando bibliotecas de classes para My

  • Compactação e implantação de Extensões

Personalizando membros existentes do Namespace My

O namespace My em Visual Basic expõe informações usadas com frequência sobre seu aplicativo, seu computador e mais.Para obter uma lista completa dos objetos no namespace My, consulte Minha referência (Visual Basic).Talvez você precise personalizar membros existentes do namespace My de forma que combinem melhor com as necessidades do seu aplicativo.Qualquer propriedade de um objeto no namespace My que é não somente leitura pode ser definida para um valor personalizado.

Por exemplo, suponha que você frequentemente use o objeto My.User para acessar o contexto de segurança atual para o usuário que estiver executando o aplicativo.No entanto, sua empresa usa um objeto de usuário personalizado para expor informações adicionais e recursos para usuários dentro da empresa.Nesse cenário, você pode substituir o valor padrão da propriedade My.User.CurrentPrincipal com uma instância do seu próprio objeto principal personalizado, como mostrado no exemplo o seguir.

My.User.CurrentPrincipal = CustomPrincipal

Configurando a propriedade CurrentPrincipal sobre os objetosMy.User altera a identidade na qual o aplicativo é executado.O objeto My.User, por sua vez, retorna informações sobre o usuário recém-especificado.

Adicionando membros a meus objetos

Os tipos retornados de My.Application e My.Computer são definidos como classes Partial.Portanto, você pode estender os objetos My.Application e objetos My.Computer criando uma classe Partial de nome MyApplication ou MyComputer.A classe não pode ser uma classe Private.Se você especificar a classe como parte do namespace My, você pode adicionar propriedades e métodos que serão incluídos com os objetos My.Application ou My.Computer.

Por exemplo, o exemplo a seguir adiciona uma propriedade chamada DnsServerIPAddresses ao objeto My.Computer.

Imports System.Net.NetworkInformation

Namespace My

  Partial Class MyComputer
    Friend ReadOnly Property DnsServerIPAddresses() As IPAddressCollection
      Get
        Dim dnsAddressList As IPAddressCollection = Nothing

        For Each adapter In System.Net.NetworkInformation.
          NetworkInterface.GetAllNetworkInterfaces()

          Dim adapterProperties = adapter.GetIPProperties()
          Dim dnsServers As IPAddressCollection = adapterProperties.DnsAddresses
          If dnsAddressList Is Nothing Then
            dnsAddressList = dnsServers
          Else
            dnsAddressList.Union(dnsServers)
          End If
        Next adapter

        Return dnsAddressList
      End Get
    End Property
  End Class

End Namespace

Adicionando objetos personalizados para o Namespace My

Embora o namespace My forneça soluções para várias tarefas comuns de programação, você poderá encontrar tarefas que o namespace My não aborda.Por exemplo, seu aplicativo pode acessar serviços de diretório personalizados para dados de usuário, ou seu aplicativo pode usar assemblies que não são instalados por padrão com Visual Basic.Você pode estender o namespace My para incluir soluções personalizadas para tarefas comuns que são específicas para seu ambiente.O namespace My facilmente pode ser estendido para adicionar novos membros para atender às crescentes necessidades do aplicativo.Além disso, você pode implantar suas extensões do namespace My para outros desenvolvedores como um modelo Visual Basic.

Bb531245.collapse_all(pt-br,VS.110).gifAdicionando membros para o My Namespace

Como My é namespace como qualquer outro namespace, você pode adicionar propriedades de nível superior para ele, simplesmente adicionando um módulo e especificando um Namespace de My.Anote o módulo com o atributo HideModuleName conforme mostrado no exemplo o seguir.O atributo HideModuleName assegura que o Intellisense não exibirá o nome do módulo quando ele exibe os membros do namespace My.

Namespace My
  <HideModuleName()> 
  Module MyCustomModule

  End Module
End Namespace

Para adicionar membros ao namespace My, adicione propriedades conforme necessário para o módulo.Para cada propriedade adicionada ao namespace My, adicione um campo particular do tipo ThreadSafeObjectProvider(Of T), onde o tipo é o tipo retornado pela sua propriedade personalizada.Este campo é usado para criar instâncias do objeto de thread de segurança a ser retornado pela propriedade chamando o método GetInstance.Como resultado, cada thread que está acessando a propriedade estendida recebe sua própria instância do tipo retornado.O exemplo a seguir adiciona uma propriedade chamada SampleExtension que é do tipo SampleExtension ao namespace My:

Namespace My
  <HideModuleName()> 
  Module MyCustomExtensions
    Private _extension As New ThreadSafeObjectProvider(Of SampleExtension)
    Friend ReadOnly Property SampleExtension() As SampleExtension
      Get
        Return _extension.GetInstance()
      End Get
    End Property
  End Module
End Namespace

Adicionar eventos a objetos My personalizados

Você pode usar o objeto My.Application para expor os eventos para os seus objetos My personalizados estendendo a classe parcial MyApplication no namespaceMy.Para projetos baseados no Windows, você pode clicar duas vezes o nó My Project para o seu projeto em Solution Explorer.Na Visual Basic Project Designer ,clique na guia Application e, em seguida, clique no botão View Application Events.Um novo arquivo chamado ApplicationEvents.vb será criado.Ele contém o código a seguir para estender a classe MyApplication.

Namespace My
  Partial Friend Class MyApplication
  End Class
End Namespace

Você pode adicionar manipuladores de eventos para os seus objetos My personalizados adicionando a classe MyApplication de manipuladores de eventos personalizados.Eventos personalizados permitem que você adicione um código que será executado quando um manipulador de eventos é adicionado, removido, ou o evento é gerado.Observe que o código AddHandler de um evento personalizado executado somente se o código é adicionado por um usuário para manipular o evento.Por exemplo, considere que o objeto SampleExtension da seção anterior tem um evento Load para o qual você deseja adicionar um manipulador de eventos personalizado.O exemplo de código a seguir mostra um manipulador de eventos personalizado chamado SampleExtensionLoad que será chamado quando o evento My.SampleExtension.Load ocorrer.Quando o código é adicionado para manipular o novo evento My.SampleExtensionLoad, a parte AddHandler deste código personalizado de evento é executada.O método MyApplication_SampleExtensionLoad está incluído no exemplo de código para mostrar um exemplo de uma manipulador de eventos que manipula o evento My.SampleExtensionLoad.Observe que o evento SampleExtensionLoad estará disponível quando você selecionar a opção My Application Events em uma lista suspensa a esquerda acima do editor de código quando você estiver editando o arquivo ApplicationEvents.vb.

Namespace My

  Partial Friend Class MyApplication

    ' Custom event handler for Load event.
    Private _sampleExtensionHandlers As EventHandler

    Public Custom Event SampleExtensionLoad As EventHandler
      AddHandler(ByVal value As EventHandler)
        ' Warning: This code is not thread-safe. Do not call
        ' this code from multiple concurrent threads.
        If _sampleExtensionHandlers Is Nothing Then
          AddHandler My.SampleExtension.Load, AddressOf OnSampleExtensionLoad
        End If
        _sampleExtensionHandlers = 
            System.Delegate.Combine(_sampleExtensionHandlers, value)
      End AddHandler
      RemoveHandler(ByVal value As EventHandler)
        _sampleExtensionHandlers = 
          System.Delegate.Remove(_sampleExtensionHandlers, value)
      End RemoveHandler
      RaiseEvent(ByVal sender As Object, ByVal e As EventArgs)
        If _sampleExtensionHandlers IsNot Nothing Then
          _sampleExtensionHandlers.Invoke(sender, e)
        End If
      End RaiseEvent
    End Event

    ' Method called by custom event handler to raise user-defined
    ' event handlers.
    <Global.System.ComponentModel.EditorBrowsable( 
         Global.System.ComponentModel.EditorBrowsableState.Advanced)> 
      Protected Overridable Sub OnSampleExtensionLoad( 
                ByVal sender As Object, ByVal e As EventArgs)
      RaiseEvent SampleExtensionLoad(sender, e)
    End Sub

    ' Event handler to call My.SampleExtensionLoad event.
    Private Sub MyApplication_SampleExtensionLoad( 
        ByVal sender As Object, ByVal e As System.EventArgs
        ) Handles Me.SampleExtensionLoad

    End Sub
  End Class
End Namespace

Diretrizes de Design

Ao desenvolver extensões para o namespace My, use as diretrizes a seguir para ajudar a minimizar os custos de manutenção de seus componentes de extensão.

  • Inclua somente a extensão lógica. A lógica incluída na My extensão namespace deve incluir somente o código necessário para expor a funcionalidade necessária na My espaço para nome.Porque sua extensão será residente em projetos de usuário como código-fonte, atualizando o componente de extensão provoca um custo alto de manutenção e deve ser evitado se possível.

  • Minimize as suposições do projeto. Quando você cria suas extensões da My espaço para nome, não pressuponha que um conjunto de referências, imports de nível de projeto ou configurações do compilador específico (por exemplo, Option Strict off).Em vez disso, minimize as dependências e qualifique totalmente todas as referências de tipo usando a palavra-chave Global.Além disso, certifique-se de que a extensão compila com Option Strict para reduzir erros na extensão.

  • Isole o código de extensão. Colocando o código em um único arquivo torna a extensão mais facilmente implantáveis como um modelo de item de Visual Studio.Para obter mais informações, consulte "Compactação e implantação de Extensões" posteriormente contidas neste tópico.Colocando todo o código da extensão do namespace My em um único arquivo ou uma pasta separada em um projeto também ajudará os usuários a localizar a extensão do namespace My.

Projetando bibliotecas de classes para My

Como é o caso com a maioria dos modelos de objeto, alguns padrões de design funcionam bem no namespace My e outros não.Ao projetar uma extensão para o namespace My, considere os seguintes princípios:

  • Métodos sem-estado. Métodos de My namespace deve fornecer uma solução completa para uma tarefa específica.Certifique-se que os valores de parâmetro que são passados para o método fornecem todas as entradas necessárias para concluir uma tarefa específica.Evite a criação de métodos que se baseiam no estado anterior, como conexões abertas para recursos.

  • Instâncias globais. O estado único que é mantido na My espaço para nome é global para o projeto.Por exemplo, My.Application.Info encapsula o estado que é compartilhado em todo o aplicativo.

  • Tipos de parâmetro simples. Mantenha as coisas simples, evitando tipos complexos de parâmetro.Em vez disso, crie métodos que não tomem nenhum parâmetro de entrada ou que levam tipos simples de entrada como sequências de caracteres, tipos primitivos e assim por diante.

  • Métodos de fábrica. Alguns tipos são necessariamente difíceis de instanciar.Fornecer métodos de fábrica como extensões ao namespace My permite que você mais facilmente descobra e consuma tipos que se enquadram nessa categoria.Um exemplo de um método de fábrica que funciona bem é My.Computer.FileSystem.OpenTextFileReader.Há vários tipos de fluxo disponíveis no .NET Framework.Especificando arquivos de texto especificamente, a ajuda ao usuário OpenTextFileReader compreende qual fluxo a ser usado.

Essas diretrizes não eliminam princípios gerais de design para bibliotecas de classes.Em vez disso, eles são recomendações que são otimizadas para os desenvolvedores que estiverem usando Visual Basic e o namespace My.Para princípios gerais de design para criar bibliotecas de classes, consulte Design Guidelines for Developing Class Libraries.

Compactação e implantação de Extensões

Você pode incluir extensões de namespace My em um modelo de projeto Visual Studio, ou pode compactar as extensões e implantá-los como um modelo de item de Visual Studio.Quando você compacta as extensões de namespace My como um modelo de item Visual Studio, você pode aproveitar recursos adicionais fornecidos pelo Visual Basic.Esses recursos permitem que você incluía uma extensão quando um projeto referencia um assembly específico, ou habilita usuários para adicionar suas extensões de namespace My explicitamente, usando a página My Extensions do Project Designer do Visual Basic.

Para obter detalhes sobre como implantar as extensões de namespace My, consulte Empacotamento e implantação personalizada extensões do My (Visual Basic).

Consulte também

Referência

Minha página de extensões, Designer de projeto (Visual Basic)

Página de aplicativo, Designer de projeto (Visual Basic)

Parcial (Visual Basic)

Conceitos

Empacotamento e implantação personalizada extensões do My (Visual Basic)

Extensão do modelo de aplicativo de Visual Basic

Personalizando quais objetos estão disponíveis no meu (Visual Basic)