• 全部
  • VC综合技术
  • 互联网技术
  • MFC AppLauncher
  • .NET 技术
  • 界面
  • 进程
  • 算法
  • 硬件/系统
  • 数据库
  • VC++技术资源

大家帮我看一段串口监视程序,看有没有问题?

admireO 2001-07-21 11:38:15
程序的主要流程是:当用户执行开始操作后,监视先程开始工作,由于本程序的特点,要写的数据比较少,所以只开了一个监视线程,程序的流程是:开始(向串口写开始命令)--->收到确认-->写参数---->收到确认----->开始读大量数据(数据交给主线程处理,内存申请在监视线程里,delete在主线程里)我用的是事件驱动也就是当有EV_RXCHAR时开始读.
DWORD WINAPI CComm::ListenProc( LPVOID lpPara )
{
CComm* pComm = (CComm*) lpPara;
HANDLE hComm = pComm->GetCommHandle();
HWND hDestWnd = pComm->GetDesWndHandle();
OVERLAPPED overlap;
overlap.hEvent = ::CreateEvent( NULL,TRUE,FALSE,NULL );
if( overlap.hEvent == NULL )
{
pComm->CloseConnection();
return 0;
}
BOOL bError = FALSE;
int nIndex = 0 ;
while( pComm->IsConnected() )
{
DWORD dwMask = 0;
::GetCommMask( hComm,&dwMask );
if( !(dwMask & EV_RXCHAR) )
::SetCommMask( hComm,EV_RXCHAR );
if( !::WaitCommEvent( hComm,&dwMask,&overlap ) ) //等待事件
{
if( ::GetLastError() == ERROR_IO_PENDING ) //如果暂停了,则等待.
{
BOOL bEnd = FALSE;
HANDLE hEvent[] = { overlap.hEvent,pComm->m_hEnd };
DWORD dwRet = ::WaitForMultipleObjects( 2,hEvent,FALSE,INFINITE );
switch( dwRet )
{
case WAIT_OBJECT_0:
{
if( dwMask & EV_RXCHAR == EV_RXCHAR ) //在此读数据并进行处理.
{
char chFlag = 0;
int nRetLength = 0;
nRetLength = pComm->ReadData( &chFlag,1 );
if( nRetLength == 0 )
continue;
switch( chFlag )
{
case 'M':
{
nIndex = 0;
char * pchTemp = "收到主参数设定信息:M";
int nstrLength = strlen( pchTemp );
char *pBuffer = new char[nstrLength + 1];
if( pBuffer != NULL )
{
strncpy( pBuffer,pchTemp,nstrLength );
*(pBuffer + nstrLength ) = '\0';
::PostMessage( hDestWnd,WM_TRANSFER_DATA,(WPARAM)pBuffer,(LPARAM) 0 );
}
pComm->WriteChanPara( nIndex );
}
break;
case 'C':
{
char * pchTemp = "收到通道参数设定信息:C";
int nstrLength = strlen( pchTemp );
char *pBuffer = new char[nstrLength + 1];
if( pBuffer != NULL )
{
strncpy( pBuffer,pchTemp,nstrLength );
*(pBuffer + nstrLength ) = '\0';
::PostMessage( hDestWnd,WM_TRANSFER_DATA,(WPARAM)pBuffer,(LPARAM) 0 );
}
char chChanFlag;
int nReadLength = pComm->ReadData( &chChanFlag,1 );
if( nReadLength <= 0 )
break;
nIndex++;
if( nIndex > 3 )
{
pComm->WriteStartCommond();
break;
}
else
{
pComm->WriteChanPara( nIndex );
}
}
break;
case 'R':
{
char * pchTemp = "收到开始采集信息:R";
int nstrLength = strlen( pchTemp );
char *pBuffer = new char[nstrLength + 1];
if( pBuffer != NULL )
{
strncpy( pBuffer,pchTemp,nstrLength );
*(pBuffer + nstrLength ) = '\0';
::PostMessage( hDestWnd,WM_TRANSFER_DATA,(WPARAM)pBuffer,(LPARAM) 0 );
}
char chDataFlag;
int nReadLength = pComm->ReadData( &chDataFlag,1 );
if( nReadLength <= 0 )
break;
while( chDataFlag == 'D' )
{
char *pBuffer = new char[14];
if( pBuffer == NULL )
{
bEnd = TRUE;
break;
}
nReadLength = pComm->ReadData( pBuffer,14 );
while( nReadLength < 14 )
{
int nNextRead = pComm->ReadData( pBuffer + nReadLength,14 - nReadLength );
nReadLength += nNextRead;
}
::PostMessage( hDestWnd,WM_TRANSFER_DATA,(WPARAM)pBuffer,14 ); //通知主窗口有数据到达.
char chEndFlag;
nReadLength = pComm->ReadData( &chEndFlag,1 );
if( nReadLength <= 0 )
break;
nReadLength = pComm->ReadData( &chDataFlag,1 );
if( chDataFlag == 'Q' )
bEnd = TRUE; //结束测量.
}
}
break;
case 'D':
{
char chDataFlag = 'D';
while( chDataFlag == 'D' )
{
char *pBuffer = new char[14];
if( pBuffer == NULL )
{
bEnd = TRUE;
break;
}
int nReadLength = pComm->ReadData( pBuffer,14 );
while( nReadLength < 14 )
{
int nNextRead = pComm->ReadData( pBuffer + nReadLength,14 - nReadLength );
nReadLength += nNextRead;
}
::PostMessage( hDestWnd,WM_TRANSFER_DATA,(WPARAM)pBuffer,14 ); //通知主窗口有数据到达.
char chEndFlag;
nReadLength = pComm->ReadData( &chEndFlag,1 );
if( nReadLength <= 0 )
break;
nReadLength = pComm->ReadData( &chDataFlag,1 );
if( chDataFlag == 'Q' )
bEnd = TRUE; //结束测量.
}
}
break;
case 'Q':
{
bEnd = TRUE;
}
break;
case 'E':
{
bEnd = TRUE;
}
break;
case 'P':
break;
case 'Z':
{
char *pBuffer = new char[14];
int nReadLength = pComm->ReadData( pBuffer,14 );
while( nReadLength < 14 )
{
int nNextRead = pComm->ReadData( pBuffer + nReadLength,14 - nReadLength );
nReadLength += nNextRead;
}
::PostMessage( hDestWnd,WM_TRANSFER_ZERO,(WPARAM)pBuffer,14 );
char chEndFlag;
pComm->ReadData( &chEndFlag,1 );
}
break;
default:
break;
}
}
}
break;
case WAIT_OBJECT_0 + 1:
{
::ResetEvent( pComm->m_hEnd );
bEnd = TRUE; //退出
}
break;
default:
break;
}
if( bEnd )
break;
}
else
{
bError = TRUE; //读数据出错.
break;
}
}
}
::CloseHandle( overlap.hEvent );
pComm->m_hThread = NULL;
if( bError )
pComm->CloseConnection();
return 0;
}
...全文
101 点赞 收藏 12
写回复
12 条回复
切换为时间正序
当前发帖距今超过3年,不再开放新的回复
发表回复
sonicss 2001-12-07
admire0:串口中使用了WaitForSingleObject会不会丢数据呀!
回复
NowCan 2001-07-30
还看到了你的回复.呵呵.
回复
NowCan 2001-07-30
我用的是

http://www.csdn.net/expert/Topic/110/110559.shtm
回复
NowCan 2001-07-30
38400
回复
admireO 2001-07-28
一次ReadFile,读出300字节吗?那你的波特率用的是多少?
回复
NowCan 2001-07-28
比如,我接受GPS的输出数据时(每秒输出一次,大约300字节)就会出现问题。我在Win2000的任务管理器看到这个进程的CPU占有率竟达到了70~80%(当然,这个占有率可能是主程序的问题),而且在关闭进程时容易造成进程无响应。这个问题我也一直没解决。你的程序可以试试看。
回复
admireO 2001-07-27
top
回复
admireO 2001-07-27
to NowCan,你的数据量很大是指有多大呢?还有如果不稳定那你是通过什么方法解决的呢?
回复
admireO 2001-07-22
top
回复
admireO 2001-07-22
怎么没人理,期待大家的关注,
回复
NowCan 2001-07-22
串口程序网上很多的,何必要自己写呢?
当然那些程序用的也都是事件驱动,和你的没什么区别。
不过我在使用时,数据量太大了就不稳定。
回复
admireO 2001-07-21
程序的关键部分是开始的怎么判断有数据读?不知道事件驱动可不可靠?
回复
相关推荐
发帖
VC/MFC
创建于2007-09-28

1.5w+

社区成员

VC/MFC相关问题讨论
申请成为版主
帖子事件
创建了帖子
2001-07-21 11:38
社区公告

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