====== 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: #include #include #include #include #include #include #include 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; } --- //[[marcos@laureano.eti.br|Marcos Laureano]] 2008/04/25 06:25//