Referências de objeto

O exemplo ObjectReferences demonstra como passar objetos por referências entre servidor e cliente. A amostra utiliza redes sociais simuladas. Uma rede social consiste em uma Person classe que contém uma lista de amigos em que cada amigo é uma instância da Person classe, com sua própria lista de amigos. Isso cria um gráfico de objetos. O serviço expõe operações nessas redes sociais.

Neste exemplo, o serviço é hospedado pelo IIS (Serviços de Informações da Internet) e o cliente é um aplicativo de console (.exe).

Nota

O procedimento de configuração e as instruções de compilação para este exemplo estão localizados no final deste tópico.

Serviço

A Person classe tem o DataContractAttribute atributo aplicado, com o IsReference campo definido para true declará-lo como um tipo de referência. Todas as propriedades têm o DataMemberAttribute atributo aplicado.

[DataContract(IsReference=true)]
public class Person
{
    string name;
    string location;
    string gender;
    int age;
    List<Person> friends;
    [DataMember()]
    public string Name
    {
        get { return name; }
        set { name = value; }
    }
    [DataMember()]
    public string Location
    {
        get { return location; }
        set { location = value; }
    }
    [DataMember()]
    public string Gender
    {
        get { return gender; }
        set { gender = value; }
    }
…
}

A GetPeopleInNetwork operação pega um parâmetro do tipo Person e retorna todas as pessoas da rede, ou seja, todas as pessoas da friends lista, os amigos do amigo, e assim por diante, sem duplicatas.

public List<Person> GetPeopleInNetwork(Person p)
{
    List<Person> people = new List<Person>();
    ListPeopleInNetwork(p, people);
    return people;

}

A GetMutualFriends operação toma um parâmetro de tipo Person e retorna todos os amigos na lista que também têm essa pessoa em sua friends lista.

public List<Person> GetMutualFriends(Person p)
{
    List<Person> mutual = new List<Person>();
    foreach (Person friend in p.Friends)
    {
        if (friend.Friends.Contains(p))
            mutual.Add(friend);
    }
    return mutual;
}

A GetCommonFriends operação leva uma lista do tipo Person. Espera-se que a lista tenha dois Person objetos. A operação retorna uma lista de Person objetos que estão nas friends listas de ambos os Person objetos na lista de entrada.

public List<Person> GetCommonFriends(List<Person> people)
{
    List<Person> common = new List<Person>();
    foreach (Person friend in people[0].Friends)
        if (people[1].Friends.Contains(friend))
            common.Add(friend);
    return common;
}

Cliente

O proxy de cliente é criado usando o recurso Adicionar referência de serviço do Visual Studio.

É criada uma rede social que consiste em cinco Person objetos. O cliente chama cada um dos três métodos no serviço.

Para configurar, compilar e executar o exemplo

  1. Certifique-se de ter executado o procedimento de instalação única para os exemplos do Windows Communication Foundation.

  2. Para criar a edição C# ou Visual Basic .NET da solução, siga as instruções em Criando os exemplos do Windows Communication Foundation.

  3. Para executar o exemplo em uma configuração de máquina única ou cruzada, siga as instruções em Executando os exemplos do Windows Communication Foundation.

Consulte também