本文实例讲述了VC串口端口应用,分享给大家供大家参考。具体用法分析如下:
串口作为最基本的电脑通信 I/O 接口,其使用虽然在 PC 上越来越少,但是在工业仪器领域仍然用的相当普遍,为此自己先整理下,希望大侠和同行们不吝赐教。
1、查询注册表
查询注册表的方法是网上见到的比较常见的方法,该方法就是使用编程方法读取注册表内信息,相当于用户通过在运行框内输入 ”regedit” (或 regedit32 )直接打开注册表,查看“
HKEY_LOCAL_MACHINE/HARDWARE/DEVICEMAP/SERIALCOMM ”项来获取串口信息。以下是源代码:
CString strSerialList[256]; // 临时定义 256 个字符串组,因为系统最多也就 256 个 HKEY hKey; LPCTSTR data_Set="HARDWARE//DEVICEMAP//SERIALCOMM//"; long ret0 = (::RegOpenKeyEx(HKEY_LOCAL_MACHINE, data_Set, 0, KEY_READ, &hKey)); if(ret0 != ERROR_SUCCESS) { return -1; } int i = 0; CHAR Name[25]; UCHAR szPortName[25]; LONG Status; DWORD dwIndex = 0; DWORD dwName; DWORD dwSizeofPortName; DWORD Type; dwName = sizeof(Name); dwSizeofPortName = sizeof(szPortName); do { Status = RegEnumValue(hKey, dwIndex++, Name, &dwName, NULL, &Type, szPortName, &dwSizeofPortName); if((Status == ERROR_SUCCESS)||(Status == ERROR_MORE_DATA)) { strSerialList[i] = CString(szPortName); // 串口字符串保存 i++;// 串口计数 } } while((Status == ERROR_SUCCESS)||(Status == ERROR_MORE_DATA)); RegCloseKey(hKey);
以上方法同样也可以实现对并口的查询,只要将 "HARDWARE // DEVICEMAP// SERIALCOMM//" 用 "HARDWARE//DEVICEMAP//PARALLEL PORTS//" 代替就行了。
比较:该方法时间最省,笔者在自己电脑上试过,在 1ms (少于 1ms 的我也不知道怎么编程计时)内即可完成;同时也可解决 usb 转串口设备的问题,比较实用,唯一缺点是,
如果用户在装某些软硬件时在注册表中注册了虚拟串口之类的,用此法枚举得到的该类串口实际上是不能当串口用的。
2 、使用 EnumPort 方法
该方法调用 EnumPort () API 函数,该函数本身就是枚举电脑端口用的,它枚举的并非只有串口,所以必须对其所得串口进行分析选择,以下是源代码:
int m_nSerialPortNum(0);// 串口计数 CString strSerialList[256]; // 临时定义 256 个字符串组 LPBYTE pBite = NULL; DWORD pcbNeeded = 0; // bytes received or required DWORD pcReturned = 0; // number of ports received m_nSerialPortNum = 0; // 获取端口信息,能得到端口信息的大小 pcbNeeded EnumPorts(NULL, 2, pBite, 0, &pcbNeeded, &pcReturned); pBite = new BYTE[pcbNeeded]; // 枚举端口,能得到端口的具体信息 pBite 以及端口的的个数 pcReturned EnumPorts(NULL, 2, pBite, pcbNeeded, &pcbNeeded, &pcReturned); PORT_INFO_2 *pPort; pPort = (PORT_INFO_2*)pBite; for ( i = 0; i < pcReturned; i++) { CString str = pPort[i].pPortName; // 串口信息的具体确定 if (str.Left(3) == "COM") { strSerialList[m_nSerialPortNum] = str.Left(strlen(str) - 1); //CString temp = str.Right(strlen(str) - 3);// 下面两行注释获取串口序号用 //m_nSerialPortNo[m_nSerialPortNum] = atoi(temp.Left(strlen(temp) - 1)); m_nSerialPortNum++; } }
该方法就是中规中矩的依次打开串口,看打开是否成功来判断串口的有无,该方法源代码如下:
int m_nSerialPortNum(0);// 串口数 CString strSerialList[256]; // 临时定义 30 个字符串组 int nCom = 0; int count = 0; HANDLE hCom; do { nCom++; strCom.Format("COM%d", nCom); hCom = CreateFile(strCom, 0, 0, 0, OPEN_EXISTING, FILE_ATTRIBUTE_NORMAL, 0); if(INVALID_HANDLE_VALUE == hCom ) break; strSerialList[m_nSerialPortNum] = strCom; m_nSerialPortNum++; CloseHandle(hCom); } while(1);
此种方法是我所见过最简单的方法,之所以简单是因为已经有人将复杂的代码封装起来了,我只需像傻子一样调用就可以完成工作了,具体的说明请看
http://www.codeguru.com/Cpp/W-P/system/hardwareinformation/article.php/c5721/ ,下面给出本人调用该方法的例子代码:
int m_nSerialPortNum(0);// 串口计数 CString strSerialList[256]; // 临时定义 256 个字符串组 CArray<SSerInfo,SSerInfo&> asi; EnumSerialPorts(asi,TRUE);// 参数为 TRUE 时枚举当前可以打开的串口, // 否则枚举所有串口 m_nSerialPortNum = asi.GetSize(); for (int i=0; i<asi.GetSize(); i++) { CString str = asi[i].strFrien dlyName; }
希望本文所述对大家的VC程序设计有所帮助。
问题内容: 我在该站点上阅读了很多有关常量用法的文章。 问题:什么时候应该使用Enums作为常量,而不是使用类或接口。 我看到了两个我要解决的关键情况。 1.多个项目在应用程序中使用的全局常数。 例: 常用日志字符串 容器引用,例如WebSphere EAR的数据库映射引用 2.对象特定常量 例: 员工对象的员工工资率 从我阅读的所有内容中,我认为我已经掌握了这些内容,并且正在寻找自己的看法。 对
问题内容: 我有一个关于在接口中放置Java枚举的问题。为了使其更清楚,请参见以下代码: 我知道一个接口由带有 空主体 的方法组成。但是,我在这里使用的枚举需要一个构造函数和一个方法来获取关联的值。在此示例中,建议的接口将不仅包含空主体的方法。是否允许这种实现? 我不确定是否应该将枚举类放入接口或实现此接口的类中。 如果将枚举放入实现此接口的类中,则方法public Number getNumbe
问题内容: 我刚刚发现Java允许枚举实现接口。有什么好的用例? 问题答案: 枚举不仅仅代表被动集(例如颜色)。他们可以代表与功能更复杂的对象,所以你可能想进一步功能添加到这些是那么-例如,你可能如接口,等等。支持这些和组件。
我有一个关于在接口中放置Java枚举的问题。为了更清楚,请看下面的代码: 我知道一个接口由带有空主体的方法组成。但是,我在这里使用的枚举需要一个构造函数和一个方法来获取关联的值。在本例中,所建议的接口将不仅仅由具有空主体的方法组成。允许这种实现吗?
综述 管理员接口可能存在与应用程序上或者应用服务器上来允许特定用户对网站进行权限操作行为。测试者应该试图去发现特权功能是否可以或者如何被非授权用户和普通用户使用。 一个应用可能需要管理接口来允许特权用户来访问那些会改变站点行为的功能。这样的行为可能包括: 用户帐号操作 网站设计和布局操作 数据操作 配置改变 在很多例子中,这些接口并没有针对非授权使用作出有效的控制措施。这个测试目标是发现这些管理接
问题内容: 我需要知道此代码的输出。但这不起作用。也许代码是错误的。我仍在学习如何使用Java,我尝试修复了几个小时,但还是没有运气。 这是代码: 谁能告诉我代码中有什么错误或遗漏吗? 问题答案: 例如: 另请注意,这可能无法打印您期望的结果。它实际上会打印: 为什么?构造函数总是链接到超类。