0
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
#include <fcntl.h>
#include <netinet/in.h>
#include <arpa/inet.h>
#include <sys/types.h>
#include <sys/socket.h>
int main()
{
int server_sockfd,client_sockfd;
int server_len,client_len;
struct sockaddr_in server_address;
struct sockaddr_in client_address;
創建一個新的socketLinux的插座接受不能被阻止
unlink("server_socket");
server_sockfd=socket(AF_INET,SOCK_STREAM,0);
命名
server_address.sin_family=AF_INET;
server_address.sin_addr.s_addr=htonl(INADDR_ANY);
server_address.sin_port=htons(9734);
server_len=sizeof(server_address);
bind(server_sockfd,(struct sockaddr *)&server_address,server_len);
組塊
int flags=fcntl(server_sockfd,F_GETFL,0);
if(flags&O_NONBLOCK==1){
printf("NONBLOCK");
}else{
printf("BLOCK");
}
flags=flags&~O_NONBLOCK;
fcntl(server_sockfd,F_SETFL,flags);
if(flags&O_NONBLOCK==1){
printf("NONBLOCK");
}else{
printf("BLOCK");
}
聽
listen(server_sockfd,5);
while(1){
char ch;
printf("server waiting\n");
client_len=sizeof(client_address);
client_sockfd=
accept(server_sockfd,(struct sockaddr*)&client_sockfd,&client_len);
其被阻擋在第一次
read(client_sockfd,&ch,1);
ch++;
write(client_sockfd,&ch,1);
close(client_sockfd);
}
}
當客戶首次連接,我的工作,但接下來將不起作用
'client_sockfd = accept'檢查client_socket的價值。它也可以是-1 - >檢查errno。同時檢查read()的返回值() – wildplasser 2013-03-16 13:28:27
套接字將在默認情況下被阻塞,因此不需要執行fcntl調用。 'unlink'調用也是不必要的。其次,你必須**檢查可能失敗的'bind'的返回值(以及'listen','socket'等等)。 – 2013-03-16 13:33:35