vs串口循环接收程序死机

vs串口循环接收程序死机,第1张

你要先确定是硬件问题还是启举此软件悄迅问题。

对比方法: 同一个程序,对比答行串口通信卡与COM1,如果COM1没死,串口通信卡死了,那应该是通信卡问题。可以换张卡试试。串口调试助手,用于COM1和串口通讯卡上有什么不同?COM1 OK,串口通讯卡不正常的话,说明程序处理有问题。

收/发一个数据会了,那收/多个的方法也相同。接收最好用中断方式,不影响其它程序执行。发送时,采用查询方式比较方便蚂樱好写。发送多个,可用岩物棚for循环控制,循环体粗则内就是发送一个数据的程序,只是循环发送了。在循环发送前,把串口中断关了,ES=0发送结束再打开中断,ES=1

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

比如,串口要给你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一起返回给你。这个时间跟波特率有关,应该是设置为在某种波特率的情况下连续两字节的最大间隔时间。


欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/yw/12365840.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-24
下一篇 2023-05-24

发表评论

登录后才能评论

评论列表(0条)

保存