关于linux 下read和select函数问题 15
我编写一个程序,使用select函数监听我的管道control_pipe,当我输入数据给管道时,比如echo"123">/路径/control_pipe,程序是读到了我的...
我编写一个程序,使用select函数监听我的管道control_pipe,当我输入数据给管道时,比如echo "123">/路径/control_pipe,程序是读到了我的数据,可那之后,我没再输入数据,select却一直认为有数据可读,但读出的数据是0个,为什么读完数据后,select还一直认为有数据可读。以下是我的其中一段程序
for(;;)
{ step.tv_sec = 5;
step.tv_usec = 0;
FD_ZERO(&read_fd);
FD_SET(sock_fd,&read_fd);
FD_SET(control_pipe,&read_fd);
if(ret=select(control_pipe+1,&read_fd,NULL,NULL,&step)>0)
{ if(FD_ISSET(sock_fd,&read_fd)||FD_ISSET(control_pipe,&read_fd))
{
if(FD_ISSET(sock_fd,&read_fd))
{ printf("new data\n");
client_fd=accept(sock_fd,(struct sockaddr*)&client_add,&len);
if(client_fd<=0)
{perror("accept() error!\n");
close(sock_fd);
return 0;
}
else
{
n=recv(client_fd,buff,100,0);
buff[n]='\0';
printf("number of receive bytes=%d data=%s\n",n,buff);
fflush(stdout);
send(client_fd,buff,n,0);
}
}
if(FD_ISSET(control_pipe,&read_fd))
{printf("control_pipe fd:%d\n",control_pipe);
int len1 = strlen(buffer);
if (len1 >= sizeof buffer -1)
{printf("long error");
memset(buffer, 0, sizeof buffer);
break;
}
if ((read_rel=read(control_pipe, &buffer, 50))==0)
{ printf( "read number %d,empty\n",read_rel);
continue;
}
printf( "receive number:%d,data=%s\n", read_rel,buffer);
}
}/*if*/
close(client_fd);
}/*select*/
if(ret==0)
printf("time out !!\n");
}/*while*/
那这是为什么第一次输入数据,读取后,select还认为有数据刻度啊?还有你下面的那段我不怎么明白,command1.value是指哪个值啊 展开
for(;;)
{ step.tv_sec = 5;
step.tv_usec = 0;
FD_ZERO(&read_fd);
FD_SET(sock_fd,&read_fd);
FD_SET(control_pipe,&read_fd);
if(ret=select(control_pipe+1,&read_fd,NULL,NULL,&step)>0)
{ if(FD_ISSET(sock_fd,&read_fd)||FD_ISSET(control_pipe,&read_fd))
{
if(FD_ISSET(sock_fd,&read_fd))
{ printf("new data\n");
client_fd=accept(sock_fd,(struct sockaddr*)&client_add,&len);
if(client_fd<=0)
{perror("accept() error!\n");
close(sock_fd);
return 0;
}
else
{
n=recv(client_fd,buff,100,0);
buff[n]='\0';
printf("number of receive bytes=%d data=%s\n",n,buff);
fflush(stdout);
send(client_fd,buff,n,0);
}
}
if(FD_ISSET(control_pipe,&read_fd))
{printf("control_pipe fd:%d\n",control_pipe);
int len1 = strlen(buffer);
if (len1 >= sizeof buffer -1)
{printf("long error");
memset(buffer, 0, sizeof buffer);
break;
}
if ((read_rel=read(control_pipe, &buffer, 50))==0)
{ printf( "read number %d,empty\n",read_rel);
continue;
}
printf( "receive number:%d,data=%s\n", read_rel,buffer);
}
}/*if*/
close(client_fd);
}/*select*/
if(ret==0)
printf("time out !!\n");
}/*while*/
那这是为什么第一次输入数据,读取后,select还认为有数据刻度啊?还有你下面的那段我不怎么明白,command1.value是指哪个值啊 展开
1个回答
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询