首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 操作系统 > UNIXLINUX >

将要看看accept函数什么时候能遇到EINTR

2013-01-28 
就要看看accept函数什么时候能遇到EINTR#include stdio.h#include sys/types.h#include sys/socket.h

就要看看accept函数什么时候能遇到EINTR

#include <stdio.h>

#include <sys/types.h>

#include <sys/socket.h>

#include <sys/un.h>

#include <errno.h>

#include <unistd.h>

#include <signal.h>

#include <sys/wait.h>

#include <netdb.h>

#include <pthread.h>



//线程执行函数负责读写

void *thr_fn(void *arg)

{

int size,j;

    char recv_buf[1024];

int *parg=(int *)arg;

int new_fd=*parg;

printf("new_fd=%d\n",new_fd);

while((size=read(new_fd,recv_buf,1024))>0)

{

if(recv_buf[0]=='@')

break;

printf("Message from client(%d): %s\n",size,recv_buf);

for(j=0;j<size;j++)

recv_buf[j]=toupper(recv_buf[j]);

write(new_fd,recv_buf,size);

}

close(new_fd);

return 0;

}





int main(int argc,char *argv[])

{

    socklen_t clt_addr_len;

int listen_fd;

int com_fd;

int ret;

int i;

static char recv_buf[1024];

int len;

int port;

pthread_t tid;



struct sockaddr_in clt_addr;

struct sockaddr_in srv_addr;



//服务器端运行时要给出端口信息,该端口为监听端口 

if(argc!=2)

{

    printf("Usage:%s port\n",argv[0]);

return 1;

}



//获得输入的端口 

port=atoi(argv[1]);



//创建套接字用于服务器的监听 

listen_fd=socket(PF_INET,SOCK_STREAM,0);

if(listen_fd<0)

{

    perror("cannot create listening socket");

return 1;

}



//填充关于服务器的套节字信息

memset(&srv_addr,0,sizeof(srv_addr));

srv_addr.sin_family=AF_INET;

srv_addr.sin_addr.s_addr=htonl(INADDR_ANY);

srv_addr.sin_port=htons(port);





//将服务器和套节字绑定

ret=bind(listen_fd,(struct sockaddr *)&srv_addr,sizeof(srv_addr));

if(ret==-1)

{

    perror("cannot bind server socket");

close(listen_fd);

return 1;

}



//监听指定端口,连接5个客户端 

ret=listen(listen_fd,5);

if(ret==-1)

{

    perror("cannot listen the client connect request");

close(listen_fd);

return 1;

}

//对每个连接来的客户端创建一个线程,单独与其进行通信 

//首先调用read函数读取客户端发送来的信息 

//将其转换成大写后发送回客户端 

//当输入“@”时,程序退出 

while(1)

{

    len=sizeof(clt_addr);

com_fd=accept(listen_fd,(struct sockaddr *)&clt_addr,&len);

if(com_fd<0)

{

    if(errno==EINTR)

{

                printf("Yes Sir,I get a EINTR!!\n");

    continue;

}

else

{

    perror("cannot accept client connect request");



close(listen_fd);

return 1;

}

}

printf("com_fd=%d\n",com_fd);//打印建立连接的客户端产生的套节字

if((pthread_create(&tid,NULL,thr_fn,&com_fd))==-1)

{

    perror("pthread_create error");

close(listen_fd);

close(com_fd);

return 1;

}

}

return 0;

}


我搜了一下大家讲的都是系统会在一直没有客户端连接就会给这个进程一个EINTR的错误返回,也是“信号”。都是预言帝,我就让其一直运行,就想等来这个EINTR,很遗憾一直没有等到,大牛们认谁能给我个主意呢? EIINTR accept 服务器 server socket
[解决办法]
你不给它发信号?
[解决办法]
加个信号处理函数,然后给进程发个信号啊!

热点排行