各位大侠,我写了一个linux下我写了个程序验证串口接收数据情况,是个死循环read,发现串口需要分多次read

首先,默认的串口文件的缓存方式是无缓冲。其次,串口在发送数据的时候不是连续的。

比如,串口要给你0x62,0x77。那么他就先发0x62后发0x77。而如果你在他发完0x62的时候马上就read()那就会只得到0x62.而0x77要再read一次。

如果你想一次就全读上来,那有两个方法。

1:你自己写一个读串口的函数,里面调用read;

例如:

int tipc_read_socket( int sockfd, char *buf, int len )

{

int count = 0; //每次读取字节数

int pos = 0; //总***读取字节数

pos = 0;

do {

count = read(sockfd, &buf[pos], len - pos);

//printf("tipc_read_socket:count[%d]\n", count);

if( 0 > count )

{

if( EINTR == errno )

continue;

//当设置为non block的时候,第一次把所有的数据读取完以后,第二次的结果为-1.

return( pos );

}

if( 0 == count ) break; /* Nothing left! */

pos += count;

} while( len > pos );

return( pos );}

2:你设置一下输入输出属性。

struct termios newtio;

bzero( &newtio, sizeof( newtio ) );

newtio.c_cc[VTIME] = ***;

newtio.c_cc[VMIN] = ***;

tcsetattr(fd,TCSANOW,&newtio);

这个里面的VTIME,VMIN。就是读等待的时间。

设置了以后,比如你读0x62的时候read,那么他会等待你设置的时间,如果在这个时间里面0x77来了,那他会把0x62和0x77一起返回给你。这个时间跟波特率有关,应该是设置为在某种波特率的情况下连续两字节的最大间隔时间。