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
Certifique-se de ter executado o procedimento de instalação única para os exemplos do Windows Communication Foundation.
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.
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.