串口通信接受处理速度跟不上发送速度的问题怎样解决??

pingyuanwei 2011-04-27 09:14:10
我的串口程序用的是一个串口类,编译环境Visual C++ 6.0。

串口类中定义用户消息
#define WM_COMM_RXCHAR WM_USER+7 // A character was received and placed in the input buffer.

在主对话框类头文件中,声明函数:
afx_msg LONG OnCommunication(WPARAM ch,LPARAM port);

在主对话框类源文件中,完成消息映射:
ON_MESSAGE(WM_COMM_RXCHAR,OnCommunication)

消息处理函数:
LONG CSCommDlg::OnCommunication(WPARAM ch,LPARAM port)
{

完成字符的接收及一帧数据的处理
......

}

我的数据的帧结构是:
在此举个例子说明:"AA 55 00 00 04 00 03 "
其中"AA 55 "为帧头,"00 00 04 00"为数据位,转化为十进制代表1024,"03 "为校验,校验规则是把AA+55+00+00+04+00=103,取"03 "作为校验位.

我有一个如上结构帧的数据文件,该文件有3021帧.
现在的问题是当波特率选为38400bps时,接收端数据处理速度能够跟上发送速度(即能够同步),并且能数据能够实时的显示在对话框的画图区,实际接收帧数为3021帧;


但当波特率选为115200bps时,接收端数据处理速度就不能跟发送速度,当接收到1700多帧时局出现误码丢帧现象;
问题应该是由于接收处理速度慢,造成读缓冲区没读完,就被发送来的新的数据所覆盖,从而出现误码丢帧现象。
而要求波特率在460800bps时,该程序仍能工作,即实时显示数据波形。

怎样解决这个问题呢?想听听大家的意见。在此先谢过。
...全文
3214 12 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
12 条回复
切换为时间正序
请发表友善的回复…
发表回复
chenjiawei007 2011-04-29
  • 打赏
  • 举报
回复
你可以做个监测 。
int nMaxBufferSize = 1024;

int nlen = readfile返回读取长度,

if(nlen == nMaxBufferSize )
printf("warning Buffer Size not enough");

以此来扩大你的缓冲大小,因为线程读取串口的开销比较大,我觉得1024的缓存可能不够大。

其实你可以根据你的波特率大小来选择你的buffer大小,这样灵活些。
chenjiawei007 2011-04-29
  • 打赏
  • 举报
回复
你读串口数据,然后进行自己的数据拼接吗?还是直接播放?

如此快的速度,你用1024的缓存接受,你可以跟下断点,基本都是1024吧?

如果出现了1024那基本就是满出了,你可以设置的大一点,1024才1K的,

根据你数据流的大小增大缓存,不知道缓存上限是多少,你开大点,再尝试下。
pingyuanwei 2011-04-29
  • 打赏
  • 举报
回复
[Quote=引用 9 楼 chenjiawei007 的回复:]
我们这硬件设备115200就是最高了,想紧紧通过串口提高到如此高的波特率有些难啊。

你的问题,是不是串口接收端根本来不及接受呢?你的串口缓冲区开辟的是多大?

如此快的速度,你缓冲区太小,导致溢出,你线程去取出串口数据时其实已经可能丢失了。
[/Quote]
我的串口板波特率最高可达到921600bps。
接收缓冲区大小为1024。
我是想实时处理这些数据并以波形图显示,达到发送与接收显示同步。
正如你说的,应该是来不及接收,有什么更好的解决方法吗?
chenjiawei007 2011-04-29
  • 打赏
  • 举报
回复
我们这硬件设备115200就是最高了,想紧紧通过串口提高到如此高的波特率有些难啊。

你的问题,是不是串口接收端根本来不及接受呢?你的串口缓冲区开辟的是多大?

如此快的速度,你缓冲区太小,导致溢出,你线程去取出串口数据时其实已经可能丢失了。
pingyuanwei 2011-04-29
  • 打赏
  • 举报
回复
回复:zhxingway
谢谢你的建议!
pingyuanwei 2011-04-29
  • 打赏
  • 举报
回复
回复miy_autumn:
你想问的是判断文件接收完成的判断吗?如果是这样,
串口类中定义用户消息
#define WM_COMM_TXEMPTY_DETECTED WM_USER+9 // The last character in the output buffer was sent.


在主对话框类头文件中,声明函数:
afx_msg LONG OnFileSendingEnded(WPARAM wParam,LPARAM port);

在主对话框类源文件中,完成消息映射:
ON_MESSAGE(WM_COMM_TXEMPTY_DETECTED,OnFileSendingEnded)

消息处理函数:
LONG CSCommDlg::OnFileSendingEnded(WPARAM wParam,LPARAM port)
{

......

}
zhxingway 2011-04-29
  • 打赏
  • 举报
回复
[Quote=引用 2 楼 zgl7903 的回复:]
1改协议 每帧多发一些数据, 以降低头部和校验开销
2开线程接受和处理,通过消息处理的效率很低
[/Quote]

你这个要求比较严格呀,找个多线程的串口通信控件或方式就可以了。

搜索“多线程串口通信”
pingyuanwei 2011-04-29
  • 打赏
  • 举报
回复
回复zgl7903:能稍微具体说一下你的第二条方案吗?谢谢
pingyuanwei 2011-04-29
  • 打赏
  • 举报
回复
回复vcf_reader:
我提的问题的确不清楚。
1、帧结构不是我定义的,是一个确定的帧结构,不能由我更改。
2、3021帧在这里我想说明的是:当波特率为19200bps时,发送端发送3021帧的数据文件大约耗时30s(计算式为3021*21*9/19200=29.73s,停止位为1位,校验位无)左右,此时,接收端要想和发送端同步,每帧的处理速度10ms左右,程序可以正常同步;
当波特率为115200bps时,发送端发送3021帧的数据大约耗时5s左右,此时,接收端要想和发送端同步,每帧的处理速度大约1.65ms,程序跟不上发送速度,出现误码丢帧现象。
当波特率为460800bps时,发送端发送3021帧的数据大约耗时1.24s左右,此时,接收端要想和发送端同步,每帧的处理速度大约0.41ms,程序跟不上发送速度,出现误码丢帧现象。
Forrest 2011-04-29
  • 打赏
  • 举报
回复
楼主是怎么判断 串口 一帧数据接收完成 的 ? 就是以仕么作为接收完整条件?

我也在做串口 ?麻烦楼主分享一下 ! 非常 谢谢1
zgl7903 2011-04-29
  • 打赏
  • 举报
回复
1改协议 每帧多发一些数据, 以降低头部和校验开销
2开线程接受和处理,通过消息处理的效率很低
vcf_reader 2011-04-28
  • 打赏
  • 举报
回复
不明白楼主想说什么?每帧才 7 个字节。
假如每秒钟传一帧,怎么可能来不及收呢?
如果你是用Windows的定时器定时发送,发送间隔也将至少达到 55 ms。

每间隔55毫秒才发送7个字节,不论波特率设置成多少,都来得及接收。

另外也想告诉楼主,你那个3021帧数据根本不是用来说事的。
打个比方说,有1万斤粮食扛回家,你扛得动吗?反正我是扛得动的,3岁小孩都扛得动,每次扛1斤就是了。

所以我根本不明白楼主到底想说什么。

我实战过,9600 bps 的情下,每55毫秒可以成动的发送和接收一帧数据。每帧数据大概是500字节!!!!
001、VB串口通讯视频教程源码41个 002、Visual Basic串口通信工程开发实例导航随书源码7个 003、Visual Basic串口通信与测控应用技术实战详解 源代码(15个全) 004、GE PLC串口通讯,VB编制,读取内存单元 005、PC机与51单片机之间的串口通讯,VB编的,分PC和单片机两部分 006、VB6的串口通信程序,还有crc校验 007、VB Modbus RTU源码,其中协议部分已生成DLL,可直接调用 008、VB.net开发的串口调试程序 009、VB.net实现串口编程,希望大家有用 010、VB版串口调试程序,包含VB源码及安装文件,适合调试串口 011、VB编程RS232串口控制DA数模转换 012、VB编程实现的串口调试工具源码 013、VB编写的RS232串口通信测试程序,以txt格式接受,可定义发送字符 014、VB编写的SouthStar串口测试与51串口烧写器V1.0版 015、VB编写的串口调试助手1.0的源码 016、VB编写的串口短信发送程序,需要数据线支持 017、VB编写的串口通信程序,实现多机通信 018、VB编写的串口通信程序,主要用于上位机与下位机间的通信 019、VB编写的串口通信程序界面参考网上的程序较简单 020、VB编写的串口通讯界面,主要面向51单片机的串口通信 021、VB编写的单片机和PC串口通信的调试程序 022、VB编写的仿真实电子琴操作界面,包含与FPGA串口通信的功能 023、VB串口API通讯,附带BAS文件全部源码,实现与饭卡读卡器通讯 024、VB串口编程,关于上位机的应用,特别适合初级学习VB的学员 025、VB串口编程调试精灵源码 026、VB串口编程实现完整的多费率电表读数软件 027、VB串口程序,,是一个串口使用例程,对初学者有用,特别是工控类的 028、VB串口传输文本,实现2台PC间的通信,类似简单的聊天工具 029、VB串口的一个电子称的项目 030、VB串口调试程序,用于通过串口控制松下空调测试 031、VB串口调试程序及源码 032、VB串口调试软件源代码,可以参考修改为其它通讯程序 033、VB串口调试软件源文件 034、VB串口控制步进电机程序完整源码 035、VB串口通信 6路10位AD转换数据采集源程序 036、VB串口通信,API串口通信模块源码 037、VB串口通信,适用简单,适合初学者 038、VB串口通信操作界面,进行数据采集,画实时曲线 039、VB串口通信程序,可以读取串口并显示保存数据,且能显示数据曲线 040、VB串口通信的源码,学习的好资料 041、VB串口通信调试器的源码程序 042、VB串口通信设计视频演示源码 043、VB串口通信示例 044、VB串口通信数据源码 045、VB串口通信之串口接收程序 046、VB串口通讯测试源代码,有文本和图形两种端口数据观察方式 047、VB串口通讯程序,用来跟单片机通讯 048、VB串口通讯代码(部分) 049、VB串口通讯的参考源程序 050、VB串口通讯实例 高精度电压表(24bit) VB源程序 051、vb串口通讯示例 052、VB串口与伺服电机DSP2407通讯完整代码源程序 053、VB串口源码,动力电池检测数据采集,内含电导巡检模块通讯报文,可,读写,保存,备份数据 054、VB串口字节通信程序,包括:1字节发送子程序,n字节接收子程序 055、VB串行口通信测试示例 056、VB串行通信试验程序 057、VB的MODEM通信源代码,智能化水电远端数据读取系统 058、VB的串口源程序,包括串口的配置界面,接收功能和发送功能 059、VB访问串口,并读取电子秤上显示的数据 060、VB和西门子S7-300 PLC串口通讯程序能实现读写功能 061、VB检测串口工作状态 062、VB简单的串口短信收发功能,使用短信猫测试通过 063、VB开发串口通信,关于生物医学工程专业的血氧饱和度的设计 064、VB开发串口通信软件,利用按钮控件控制高清晰数字展示台 065、VB开发的RS232串口图像处理器驱动(摄像头驱动) 066、VB开发的串口通信源码 067、VB开发的串口与三菱FX PLC通讯源码 068、VB控制串口232通讯,对飞利浦M1卡内数据进行处理,支持密码修改等 069、VB利用Mscomm控件编写的通讯终端,可做串口通讯编程参考示例 070、VB平台单片机与PC机串口通信的PC端程序。小巧易用,功能丰富 071、VB嵌入式串口通讯波形分析显示软件 072、VB实现串口调试LED信息显示屏设备主要代码 073、VB实现串口调试工具的完整源码 074、vb实现串口通信 文件传送系统,用vb以及mscomm控件实现 075、VB实现串口通信发送命令从而接收相应数据 076、VB使用mscom控件实现PC机与单片机串口通信 077、VB通过COM串口读取条形码设备 078、VB通过串口控制单片机读写24C02源代码 079、VB通讯程序,连接串口可在电脑显示来电号码 080、VB下的串口发短信程序,可选择端口,设置短信中心号码 081、VB写的串口通信发送和接收实例 082、VB写的串口通信分析程序源码 083、VB写的串口通讯,通过串口对单片机进行控制 084、VB写的串口通讯软件,简单易学,适合初学者 085、VB写的通过串口与考勤机连接通讯的程序 086、vb用控件的写的串口程序,是vb的经典之作 087、VB与USB转串口的通讯完整程序,有详细说明,不需要安装驱动 088、vb与串口通信的关于回路测试的小程序很实用 089、vb语言开发的串口通信,可实现拨号传送文件等 090、VB中串口事件处理函数的示例 091、VB中的串口通讯,串口通讯作为一种古老而又灵活的通讯方式,被广泛地应用 092、VB自动枚举系统串口加摄象头图象采集,坐标系变换 093、Visual Basic2005与自动化系统监控(串并行控制)光盘

15,980

社区成员

发帖
与我相关
我的任务
社区描述
VC/MFC 界面
社区管理员
  • 界面
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧