Ferramentas do usuário

Ferramentas do site


listen

Diferenças

Aqui você vê as diferenças entre duas revisões dessa página.


listen [2023/09/12 16:14] (atual) – criada - edição externa 127.0.0.1
Linha 1: Linha 1:
 +====== Função listen ======
 +Sintaxe:
 +
 +''[[tipos_dados|int]] listen([[tipos_dados|int]] iSocket, [[tipos_dados|int]] backlog);''
 +
 +----
 +
 +
 +Após o socket (função [[socket]]) ter sido criada e uma porta associada (função [[bind]]) é necessário habilitar o socket para receber as conexões. A função **listen** faz justamente este papel ou seja, habilita que o programa servidor receba conexões de um programa cliente. Deve-se passar o descritor do [[socket]] aberto e a quantidade de conexões que podem ficar pendentes até que o programa trate todas as conexões anteriores. A função retorna 0 (zero) em caso de sucesso e –1 em caso de erro.
 +
 +Veja o exemplo:
 +
 +<code c>
 +#include <stdio.h>
 +#include <stdlib.h>
 +#include <strings.h>
 +#include <errno.h>
 +#include <sys/types.h>
 +#include <sys/socket.h>
 +#include <netinet/in.h>
 +
 +int main(void)
 +{
 +   int iSock;
 +   struct sockaddr_in my_addr;
 +
 +   iSock = socket(AF_INET, SOCK_STREAM, 0);
 +   if( iSock == -1)
 +   {
 +      perror("socket:");
 +      exit(1);
 +   }
 +
 +   my_addr.sin_family = AF_INET;
 +   my_addr.sin_port = htons(4950);
 +   my_addr.sin_addr.s_addr = INADDR_ANY;
 +   bzero(&(my_addr.sin_zero), 8);
 +
 +   if( bind(iSock, (struct sockaddr *)&my_addr, sizeof(struct sockaddr)) == -1)
 +   {
 +      perror("bind:");
 +      exit(1);
 +   }
 +
 +   if( listen( iSock, 10 ) < 0)
 +   {
 +      perror("listen:");
 +      exit(1);
 +   }
 +
 +   return 0;
 +}
 +</code>
 +
 + --- //[[marcos@laureano.eti.br|Marcos Laureano]] 2008/04/25 06:25//