在串口通讯中,在vc下使用多个串口,在com10以上应怎么处理? 在我的串口通讯程序中,当达到com10以后,vc下用函数createfile创建端口编程就出现了问题,请问各位应怎么处理? 解决方案 » 免费领取超大流量手机卡,每月29元包185G流量+100分钟通话, 中国电信官方发货 不知道楼主的问题解决了没有。如果没有可以看看我的建议,应该不会白看的楼主如果用MSCOMM32.ocx控件的话,就不会有这个问题了。如果用CreateFile()来打开串口的话,其中参数lpszPortNum指的就是串口名,如"COM1","COM2",,"COM9"。为什么只到"COM9",因为从"COM10"以后名字不一样了。如串口10,对应的参数为"\\\\.\\COM10",至于串口11以后的,我就不说了,楼主应该能想到了。至于要枚举出一台机子得所有串口,楼上回答过这个问题,我不说了 我使用了一个CSerialPort 的串口类,并未见到有何异常void CLSComm::Initialize(UINT uBaud, char chParity, UINT uDataBits, float fStopBits){ m_uBaudRate = uBaud; m_chParity = chParity; m_uDataBits = uDataBits; if (fStopBits == 1.5) // 1.5 个停止位 m_uStopBits = 2; else if(fStopBits > 1.5) // 2 个停止位 m_uStopBits = 3; else m_uStopBits = 1; // 1 个停止位}BOOL CLSComm::OpenDevice(UINT uPort, HWND hMsgTarget){ BOOL bResult = FALSE; TCHAR szPort[MAX_PATH]; TCHAR szBaud[MAX_PATH]; m_uCommPort = uPort; m_hTargetWindow = hMsgTarget; CloseDevice(); m_hWriteEvent = CreateEvent(NULL, TRUE, FALSE, NULL); // 发送数据事件 m_hShutdownEvent = CreateEvent(NULL, TRUE, FALSE, NULL); // 关闭线程的事件 m_ovComm.hEvent = CreateEvent(NULL, TRUE, FALSE, NULL); // 读取数据事件 m_hEventArray[USER_EVENT_QUIT] = m_hShutdownEvent; m_hEventArray[USER_EVENT_RECEIVE] = m_ovComm.hEvent; m_hEventArray[USER_EVENT_SEND] = m_hWriteEvent; wsprintf(szPort, _T("\\\\.\\COM%d"), m_uCommPort); wsprintf(szBaud, _T("baud=%d parity=%c data=%d stop=%d"), m_uBaudRate, m_chParity, m_uDataBits, m_uStopBits); InitializeCriticalSection(&m_csCritical); EnterCriticalSection(&m_csCritical); // 打开串口设备 m_hDevice = CreateFile(szPort, GENERIC_READ | GENERIC_WRITE, 0, NULL, OPEN_EXISTING, FILE_FLAG_OVERLAPPED, 0); if (m_hDevice == INVALID_HANDLE_VALUE) { m_hDevice = NULL; return FALSE; } if (SetCommTimeouts(m_hDevice, &m_timeoutComm)) { if (SetCommMask(m_hDevice, EV_RXCHAR | EV_TXEMPTY | EV_CTS)) { if (GetCommState(m_hDevice, &m_dcbComm)) { m_dcbComm.fRtsControl = RTS_CONTROL_ENABLE; //m_dcbComm.fRtsControl = RTS_CONTROL_DISABLE; //m_dcbComm.fDtrControl = DTR_CONTROL_ENABLE; if (BuildCommDCB(szBaud, &m_dcbComm)) { if (SetCommState(m_hDevice, &m_dcbComm)) { PurgeComm(m_hDevice, PURGE_RXCLEAR | PURGE_TXCLEAR | PURGE_RXABORT | PURGE_TXABORT); m_hCommThread = CreateThread(NULL, 0, _CommThread, this, 0, &m_dwCommThreadID); bResult = (m_hCommThread != NULL) ? TRUE : FALSE; } } } } } LeaveCriticalSection(&m_csCritical); if (!bResult) CloseDevice(); else m_bThreadAlive = TRUE; return bResult; } 注:我同时驱动了16个串口,使用了COM20 COM1和COM10并未有所区别,应该检查其他部分的代码,而不要归结于是COM10还是COM11 我在用createfile()函数时,得到句柄时出现错误,报错是:大部开端口,各位有没有遇到过这个问题?应怎么解决? qrlvls(≌AIR⌒LIKE ≤空气≥) 兄,是怎么解决的则合格问题? 小于10时候加不加都行的,大于9时候就是必须要加"\\\\.\\"比如串口10,对应的参数为"\\\\.\\COM10", 问一个做管理系统,关于数据库打包的问题 谁给推荐几本Exchange Server编程方面的书,要C++的 vc++ 中 关于时间的计算 IE 编程难题 呀 屏蔽了C运行库后链接错误,大家看看 帮帮忙啊 关于线程执行的顺序 为什么我的vc6.0的编译选项只有两个?? 有没有人做过三方通话的程序? 超级难题!C++,如何设置 activex 的 ocxstate 怎样打开一个word文档? 求教关于杀毒软件的工作原理````哪位大哥说说啦``这方面的资料实在是太少了``
楼主如果用MSCOMM32.ocx控件的话,就不会有这个问题了。
如果用CreateFile()来打开串口的话,其中参数lpszPortNum指的就是串口名,如
"COM1","COM2",,"COM9"。
为什么只到"COM9",因为从"COM10"以后名字不一样了。
如串口10,对应的参数为"\\\\.\\COM10",
至于串口11以后的,我就不说了,楼主应该能想到了。
至于要枚举出一台机子得所有串口,楼上回答过这个问题,我不说了
void CLSComm::Initialize(UINT uBaud, char chParity, UINT uDataBits, float fStopBits)
{
m_uBaudRate = uBaud;
m_chParity = chParity;
m_uDataBits = uDataBits; if (fStopBits == 1.5) // 1.5 个停止位
m_uStopBits = 2;
else if(fStopBits > 1.5) // 2 个停止位
m_uStopBits = 3;
else
m_uStopBits = 1; // 1 个停止位
}BOOL CLSComm::OpenDevice(UINT uPort, HWND hMsgTarget)
{
BOOL bResult = FALSE;
TCHAR szPort[MAX_PATH];
TCHAR szBaud[MAX_PATH]; m_uCommPort = uPort;
m_hTargetWindow = hMsgTarget; CloseDevice(); m_hWriteEvent = CreateEvent(NULL, TRUE, FALSE, NULL); // 发送数据事件
m_hShutdownEvent = CreateEvent(NULL, TRUE, FALSE, NULL); // 关闭线程的事件
m_ovComm.hEvent = CreateEvent(NULL, TRUE, FALSE, NULL); // 读取数据事件
m_hEventArray[USER_EVENT_QUIT] = m_hShutdownEvent;
m_hEventArray[USER_EVENT_RECEIVE] = m_ovComm.hEvent;
m_hEventArray[USER_EVENT_SEND] = m_hWriteEvent;
wsprintf(szPort, _T("\\\\.\\COM%d"), m_uCommPort);
wsprintf(szBaud, _T("baud=%d parity=%c data=%d stop=%d"), m_uBaudRate, m_chParity, m_uDataBits, m_uStopBits); InitializeCriticalSection(&m_csCritical);
EnterCriticalSection(&m_csCritical); // 打开串口设备
m_hDevice = CreateFile(szPort, GENERIC_READ | GENERIC_WRITE, 0, NULL, OPEN_EXISTING, FILE_FLAG_OVERLAPPED, 0);
if (m_hDevice == INVALID_HANDLE_VALUE)
{
m_hDevice = NULL;
return FALSE;
}
if (SetCommTimeouts(m_hDevice, &m_timeoutComm))
{
if (SetCommMask(m_hDevice, EV_RXCHAR | EV_TXEMPTY | EV_CTS))
{
if (GetCommState(m_hDevice, &m_dcbComm))
{
m_dcbComm.fRtsControl = RTS_CONTROL_ENABLE;
//m_dcbComm.fRtsControl = RTS_CONTROL_DISABLE;
//m_dcbComm.fDtrControl = DTR_CONTROL_ENABLE;
if (BuildCommDCB(szBaud, &m_dcbComm))
{
if (SetCommState(m_hDevice, &m_dcbComm))
{
PurgeComm(m_hDevice, PURGE_RXCLEAR | PURGE_TXCLEAR | PURGE_RXABORT | PURGE_TXABORT);
m_hCommThread = CreateThread(NULL, 0, _CommThread, this, 0, &m_dwCommThreadID);
bResult = (m_hCommThread != NULL) ? TRUE : FALSE;
}
}
}
}
}
LeaveCriticalSection(&m_csCritical); if (!bResult)
CloseDevice();
else
m_bThreadAlive = TRUE;
return bResult;
}