如题,我用CreateFile和ReadFile来读数据的。一般情况下都能正常通信。但是如果是系统刚启动完,第一次读串口时,怎么也读不到数据,就是ReadFile根本不返回。如果这时候我用WINDOWS带的超级终端来发送,接受一次数据后,程序就一切正常,可读数据了。不知道为什么。我是用串口线连自己的机器,一头连COM1,一头是USB转串口,模拟COM3。有谁遇到过这种问题?
调试欢乐多
m_ComportHandle = CreateFile( m_ComName,
GENERIC_READ | GENERIC_WRITE,
FILE_SHARE_READ | FILE_SHARE_WRITE,
NULL,
OPEN_EXISTING,
FILE_ATTRIBUTE_NORMAL,
NULL);
if (m_ComportHandle == INVALID_HANDLE_VALUE)
throw CComException(E_UNEXPECTED, GetLastErrorDesc(GetLastError()),
__FILE__, __LINE__);
设置状态: GetCommState( m_ComportHandle, &m_dcb );
m_dcb.BaudRate = STRTOINT(m_BAUDRATE);
m_dcb.ByteSize = STRTOINT(m_BYTESIZE);
m_dcb.fParity = STRTOINT(m_PARITY);
m_dcb.StopBits = STRTOINT(m_STOPBITS);
if( !SetCommState( m_ComportHandle, &m_dcb ))
{
DWORD errcode = GetLastError();
CloseHandle(m_ComportHandle);
throw CComException(errcode, GetLastErrorDesc(errcode), __FILE__, __LINE__);
}
读数据: if (!ReadFile(m_ComportHandle, (void*)buf, m_ComBuffer, &readed, NULL))
{
....
}
试试两个串口直接通信呢?如果还有问题,说明是你代码的问题。
试试Overlap I/O.
不明白,难道WINDOWS带的超级终端 有信号补偿功能?
估计,是你程序的问题.可能再你用串口之前 还需要一个步骤...而这个步骤 WINDOWS带的超级终端替你实现了以后 你的程序才能正常工作..
这个 我没试过..机器太老.:____( 没 USB 55555555555555
...
if(!SetupComm(CommHandle, 4096, 4096))
{
...
}
...
if(!SetCommTimeouts( CommHandle, &commtimeouts ))
{
...
}
PurgeComm(CommHandle, PURGE_TXABORT | PURGE_RXABORT |PURGE_TXCLEAR | PURGE_RXCLEAR) ;
m_dcb.BaudRate = STRTOINT(m_BAUDRATE);
m_dcb.ByteSize = STRTOINT(m_BYTESIZE);
m_dcb.fParity = STRTOINT(m_PARITY);
m_dcb.StopBits = STRTOINT(m_STOPBITS);
--------------------------------------------------------------------
这里,对dcb的每个成员附值,肯定是有部分没有初始化,所以你在GetCommState时,其中的一些成员没有初始化,或者初始化的内容和你的不一样,但你却只对其中的4个成员初始化了
COMMTIMEOUTS commTimeouts; // 串口超时 memset( &commTimeouts, 0, sizeof(COMMTIMEOUTS) );
commTimeouts.ReadIntervalTimeout = MAXDWORD; // 读立即返回
::SetCommTimeouts( m_hComm, &commTimeouts );
{
m_hTermWnd=GetSafeHwnd();
if(m_bConnect)
return FALSE;
hCom=CreateFile("COM1",//文件名
GENERIC_READ|GENERIC_WRITE, // 允许读和写
0, // 独占方式
NULL,
OPEN_EXISTING, //打开而不是创建
FILE_ATTRIBUTE_NORMAL|FILE_FLAG_OVERLAPPED, // 重叠方式
NULL
);
if(hCom == INVALID_HANDLE_VALUE)
{
dwError=GetLastError( );
return FALSE;
// 处理错误
}
SetupComm(hCom,1024,1024 ); //缓冲区的大小为1024
//清除缓冲区
PurgeComm(hCom,PURGE_TXABORT|PURGE_RXABORT|PURGE_TXCLEAR|PURGE_RXCLEAR);
//超时的建立
TimeOuts. ReadIntervalTimeout=1000;
TimeOuts.ReadTotalTimeoutMultiplier=500;
TimeOuts.ReadTotalTimeoutConstant=5000;
TimeOuts.WriteTotalTimeoutMultiplier=500;
TimeOuts.WriteTotalTimeoutConstant=5000;
SetCommTimeouts(hCom, &TimeOuts); // 设置超时
//设置事件触发方式
SetCommMask(hCom,EV_RXCHAR);
if(ConfigConnect())
{
m_pThread=AfxBeginThread(CommProc, this, THREAD_PRIORITY_NORMAL,
0, CREATE_SUSPENDED, NULL); // 创建并挂起线程
if(m_pThread==NULL)
{
CloseHandle(hCom);
return FALSE;
}
else
{
m_bConnect=TRUE;
m_pThread->ResumeThread(); // 恢复线程运行
}
}
else
{
CloseHandle(hCom);
return FALSE;
}
}BOOL CComiotestDlg::ConfigConnect()
{
DCB m_dcb;
if(!GetCommState(hCom, &m_dcb))
return FALSE;
m_dcb.fBinary=TRUE;
m_dcb.BaudRate=m_nBaud; // 波特率
m_dcb.ByteSize=m_nDataBits; // 每字节位数
m_dcb.fParity=TRUE;
switch(m_nParity) // 校验设置
{
case 0:
m_dcb.Parity=NOPARITY;
break;
case 1:
m_dcb.Parity=EVENPARITY;
break;
case 2:
m_dcb.Parity=ODDPARITY;
break;
default:;
}
switch(m_nStopBit) // 停止位
{
case 0:
m_dcb.StopBits=ONESTOPBIT;
break;
case 1:
m_dcb.StopBits=ONE5STOPBITS;
break;
case 2:
m_dcb.StopBits=TWOSTOPBITS;
break;
default:;
}
// 硬件流控制设置
//m_dcb.fOutxCtsFlow=m_nFlowCtrl==1;
//m_dcb.fRtsControl=m_nFlowCtrl==1?
//RTS_CONTROL_HANDSHAKE:RTS_CONTROL_ENABLE;
// XON/XOFF流控制设置
//m_dcb.fInX=dcb.fOutX=m_nFlowCtrl==2;
//m_dcb.XonChar=XON;
//m_dcb.XoffChar=XOFF;
//m_dcb.XonLim=50;
//m_dcb.XoffLim=50;
m_dcb.fBinary=TRUE;
return SetCommState(hCom, &m_dcb);
}