串行通讯时接收数据问题!

xuanfeng1221 2005-10-20 01:51:18
在上位机和下位机通讯时,上位机发送一指令后想等待返回数据,自制了一数据接收函数,但调试时发现执行此函数时,如果接收缓冲区里没有数据则跳出函数,不进行等待。郁闷了。请高手指点我错在哪里,我想要在该程序里停止下来,直到接收缓冲区有数据并读出后返回。
void CFY3NO2View::GetDataFromCom()//接收8031发来的数据.
{

DWORD dwEvtMaskX;
OVERLAPPED osRead;
DWORD dwErrorFlags;
COMSTAT ComStat;
DWORD dwLength=0,NUM;
BYTE abln;
char adn[9];

osRead.Offset = 0;
osRead.OffsetHigh = 0;

osRead.hEvent=CreateEvent(NULL,TRUE,FALSE,NULL);

if(osRead.hEvent==NULL)
{
AfxMessageBox("建立事件失败!", MB_OK, 0 );

}
if(!SetCommMask( COMFile,EV_RXCHAR))


dwEvtMaskX=0;
WaitCommEvent( COMFile,&dwEvtMaskX,&osRead );//本想在此等待,但如没有数据, 函数返回。如何才能留住CPU的脚步呢?
if((dwEvtMaskX&EV_RXCHAR)==EV_RXCHAR)
{ int i=0;

do{
ClearCommError( COMFile,&dwErrorFlags,&ComStat);
dwLength=ComStat.cbInQue;


if(dwLength>0)
{

ReadFile( COMFile,&abln,1,&NUM,&osRead);//

GetComDate[i]=abln;

}
else GetComDate[i]=11;
i++;
}while(dwLength>0);


}

CloseHandle(osRead.hEvent);


}
...全文
109 5 打赏 收藏 转发到动态 举报
写回复
用AI写文章
5 条回复
切换为时间正序
请发表友善的回复…
发表回复
xuanfeng1221 2005-10-20
  • 打赏
  • 举报
回复
WaitCommEvent( COMFile,&dwEvtMaskX,&osRead );
调试时发现最后一个参数如果是&osRead,则在接收缓冲区没有数据的情况下直接返回了。没有等待的过程。返回0同时if ((dwEvtMask & EV_RXCHAR) == EV_RXCHAR)中的条件不满足。根本就不能执行IF下的程序。怎么回事呀。
如果换成WaitCommEvent( COMFile,&dwEvtMaskX,NULL );则等待。但在XP下,最后一个参数能为NULL吗?MSDN上说不行呀。
/*lpOverlapped
Pointer to an OVERLAPPED structure. This structure is required if hFile was opened with FILE_FLAG_OVERLAPPED.
If hFile was opened with FILE_FLAG_OVERLAPPED, the lpOverlapped parameter must not be NULL. It must point to a valid OVERLAPPED structure. If hFile was opened with FILE_FLAG_OVERLAPPED and lpOverlapped is NULL, the function can incorrectly report that the operation is complete. */
legendhui 2005-10-20
  • 打赏
  • 举报
回复
bSuccess = WaitCommEvent(m_hCom, &mask, &m_ovRead);

if ( ! bSuccess )
{
int err = GetLastError();

if ( err == ERROR_IO_PENDING)
{
result = WaitForSingleObject(m_ovRead.hEvent, dwMaxWait); //wait dwMaxWait
// milli seconds before returning
if ( result == WAIT_TIMEOUT )
{
// Handle the error.
bSuccess = CloseHandle(m_ovRead.hEvent);
ComAccess::ErrorToString("ReadData(): WaitForSingleObject() failed");
return(-1);
}
}
}

// The specified event occured?

if ( mask & EV_RXCHAR )
{
ReadFile( COMFile,&abln,1,&NUM,&osRead);//以后按你的程序读文件就行了
}
yayaniuniu502 2005-10-20
  • 打赏
  • 举报
回复
while(dwLength>0);条件有问题
pawnbroker 2005-10-20
  • 打赏
  • 举报
回复
开一个单独的读数据线程:这个线程是一个死循环
while(1)
{
BOOL bReadResult = ReadFile(pSerial->m_hCom, &byRxChar_Gprs,1, &dwLength_Gprs, NULL);
//从串口读取数据
if (bReadResult && (dwLength_Gprs > 0))
{
//有数据,处理
//发消息
}
//没数据,循环
}


由于是线程,不影响其他处理
DentistryDoctor 2005-10-20
  • 打赏
  • 举报
回复
if ((dwEvtMask & EV_RXCHAR) == EV_RXCHAR)
{
ClearCommError(m_hFile, &dwErrorFlags, &ComStat);
dwLen = min(ComStat.cbInQue, MAX_COM_MSG_LEN);
dwLength = 0;
BOOL bRead = ReadFile(m_hFile, (void*)m_pcRecvBuf, dwLen, &dwLength, &m_ReadOs);
dwError = GetLastError();

if (dwLength && bRead && dwError==0){
bSend = true;
}
if (!bRead && ERROR_IO_PENDING==dwError)
{
DWORD res = 0;
while (!GetOverlappedResult(m_hFile,&m_ReadOs, &res, TRUE))
{
if (ERROR_IO_INCOMPLETE == GetLastError())
dwLength += res;
else
{
dwLength = 0;
res = 0;
break;
}
}
dwLength += res;
if (dwLength){
}
}
else
{
ClearCommError(m_hFile,&dwErrorFlags,&ComStat ) ;
}
...
}
串口监控器是一个免费的多功能串口通讯监控软件,它能够多种方式显示,接收,分析通讯数据;能够以多种灵活方式发送数据;功能强大,操作简便,在串口通讯监控,设备通讯测试中,能够有效提高工作效率。 主要功能如下: 接收数据: 1. 以十六进制方式显示接收到的数据。 2. 以字符方式显示接收到的数据。 3. 数据帧自动识别,分行显示。 4. 接收数据自动换行设置。 5. 显示或隐藏数据帧的接收间。 6. 自动清除,自动保存接收到的数据。 7. 接收数据个数计数。 发送数据: 1. 十六进制方式发送数据。 2. 字符串方式发送数据。 3. 发送“发报窗口”当前光标行的数据帧。 4. 循环发送“发报窗口”当前光标行的数据帧。 5. 循环发送“发报窗口”固定行的数据帧。 6. 循环依次发送“发报窗口”的多行数据帧。(设置起始行,行数) 7. 触发发送,接收到“发报窗口”某一行数据,触发发送“发报窗口”另一行数据。 8. 发送数据个数计数。 实用增强功能: 1. 强大易用的进制转换功能。 2. 智能识别当前光标处数据帧的行号,“字符”或“十六进制数”的个数。 3. 智能计算当前选择的“字符”或“十六进制数”的个数。 4. 强大的数据查找功能。 5. 定保存,定清除数据。 6. 根据自己的喜好,灵活变换操作界面。 应用场合: 1. 截取和分析设备之间通讯数据流。 2. 串行外围设备硬件开发。 3. 串行设备驱动程序开发。 4. 调试和测试设备和设备之间的串行通讯过程。 5. 记录和分析RS232/422/485通信过程。 6. 模拟某设备通讯过程,对另外设备进行通讯测试。
C#串口介绍以及简单串口通信程序设计实现 源代码和串口程序介绍连接:https://www.cnblogs.com/JiYF/p/6618696.html 本站积分太贵,自己变得。。直接到连接地址下载代码 周末,没事干,写个简单的串口通信工具,也算是本周末曾来过,废话不多,直接到主题 串口介绍   串行接口简称串口,也称串行通信接口或串行通讯接口(通常指COM接口),是采用串行通信方式的扩展接口。(至于再详细,自己百度) 串口应用:   工业领域使用较多,比如:数据采集,设备控制等等,好多都是用串口通信来实现!你要是细心的话,你会发现,目前家用国网智能电能表就具备RS485通信总线(串行总线的一种)与RS232可以相互转化(当然一般,非专业的谁也不会闲的蛋疼,趴电表上瞎看,最多也就看看走了多少度电) RS232 DB9介绍: 1.示意图 2.针脚介绍: 载波检测(DCD) 接受数据(RXD) 发出数据(TXD) 数据终端准备好(DTR) 信号地线(SG) 数据准备好(DSR) 请求发送(RTS) 清除发送(CTS) 振铃指示(RI) 3.实物图: 以下是我购买XX公司的一个usb转串口线:这个头就是一个公头,另一端是一个usb口 笨小孩串口工具运行图: 1.开启程序 2.发送一行字符串HelloBenXH,直接将针脚的发送和接收链接起来就可以测试了(针脚2 接受数据(RXD) 和3 发出数据(TXD))直接链接, C#代码实现:采用SerialPort 1.实例化一个SerialPort [csharp] view plain copy 在CODE上查看代码片派生到我的代码片 private SerialPort ComDevice = new SerialPort(); 2.初始化参数绑定接收数据事件 [csharp] view plain copy 在CODE上查看代码片派生到我的代码片 public void init() { btnSend.Enabled = false; cbbComList.Items.AddRange(SerialPort.GetPortNames()); if (cbbComList.Items.Count > 0) { cbbComList.SelectedIndex = 0; } cbbBaudRate.SelectedIndex = 5; cbbDataBits.SelectedIndex = 0; cbbParity.SelectedIndex = 0; cbbStopBits.SelectedIndex = 0; pictureBox1.BackgroundImage = Properties.Resources.red; ComDevice.DataReceived += new SerialDataReceivedEventHandler(Com_DataReceived);//绑定事件 }

16,472

社区成员

发帖
与我相关
我的任务
社区描述
VC/MFC相关问题讨论
社区管理员
  • 基础类社区
  • Web++
  • encoderlee
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

        VC/MFC社区版块或许是CSDN最“古老”的版块了,记忆之中,与CSDN的年龄几乎差不多。随着时间的推移,MFC技术渐渐的偏离了开发主流,若干年之后的今天,当我们面对着微软的这个经典之笔,内心充满着敬意,那些曾经的记忆,可以说代表着二十年前曾经的辉煌……
        向经典致敬,或许是老一代程序员内心里面难以释怀的感受。互联网大行其道的今天,我们期待着MFC技术能够恢复其曾经的辉煌,或许这个期待会永远成为一种“梦想”,或许一切皆有可能……
        我们希望这个版块可以很好的适配Web时代,期待更好的互联网技术能够使得MFC技术框架得以重现活力,……

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