在IT行业中,串口通信是一种常见且重要的通信方式,尤其在嵌入式系统和设备间的交互中广泛应用。本文将深入探讨“CSerialPort类”及其针对Unicode编码的改进,以及如何修正DCB(Device Control Block)结构体初始化的错误。 让我们了解什么是CSerialPort类。CSerialPort是基于MFC(Microsoft Foundation Classes)库的一个类,用于封装Windows API中的串口通信功能。它提供了一系列的方法,使得开发者能够方便地进行串口的打开、关闭、读写、设置参数等操作,大大简化了串口编程的工作。 在原始的CSerialPort类中,可能会默认使用ANSI编码,即非Unicode编码。然而,随着多语言和全球化的发展,Unicode编码的需求越来越强烈。Unicode是一种包含全世界几乎全部字符集的编码标准,能更好地支持各种语言文字的处理。因此,对CSerialPort类进行修改以支持Unicode编码,意味着该类现在可以处理包含多种语言的数据,极大地提高了其适用性。 实现Unicode支持的关键在于数据的转换和API调用。在发送或接收数据时,需要将Unicode字符串转换为与系统匹配的格式,如UTF-8或UTF-16,然后通过适当的API函数(如WriteFile或ReadFile)进行传输。同时,接收数据后,也需要将接收到的字节流转换回Unicode字符串。这个过程可能涉及到宽字符和窄字符的转换,需要谨慎处理以避免数据丢失或乱码。 接下来,我们关注到DCB结构体的初始化问题。DCB是Windows操作系统用来控制串口设备状态的数据结构,它包含了串口的各种配置信息,如波特率、数据位、停止位、校验位等。如果在初始化DCB时设置不当,可能导致串口无法正常工作或者通信错误。修正这个问题可能包括以下几个方面: 1. 正确设置DCB的大小:确保使用`DCBlength`成员指定结构体的实际大小,以防止API函数在填充其他未初始化的成员时出现问题。 2. 使用`GetCommState`函数获取当前串口的状态作为初始值,然后再进行修改,避免因直接使用默认值导致的不兼容问题。 3. 检查并正确设置所有的串口参数,如波特率(`BaudRate`)、数据位(`DataBits`)、停止位(`StopBits`)和校验位(`Parity`)等。 4. 调用`SetCommState`函数将更新后的DCB设置到串口,确保设置生效。 在提供的文件列表中,`SerialPort.cpp`和`SerialPort.h`分别包含了CSerialPort类的实现和声明。通过对这两个文件的分析和调试,我们可以进一步了解作者是如何实现Unicode支持和修复DCB初始化错误的具体细节。 CSerialPort类的Unicode支持和DCB初始化错误修正,都是为了提高串口通信的可靠性和兼容性,使得该类在处理多语言环境下的串口通信时更加得心应手。对于开发者来说,理解这些改进背后的原理和实现方法,有助于更好地利用CSerialPort类,提升项目的质量和性能。
2025-12-16 16:14:56 8KB 支持Unicode 串口通讯类
1
串口通信作为计算机与各种数据终端之间进行连接的重要方式,广泛应用于嵌入式系统、通信设备、工业控制等领域。本文将围绕一个名为“串口通信助手-CSerialPort-0”的软件包进行介绍,该软件包主要是为开发者提供一个基于C++的串口通信库,通过它可以在应用程序中实现对串口的配置、读取和发送数据等功能。 软件包中的include文件夹包含了库函数的头文件,开发者在编写应用程序时需要引用这些头文件以调用库中的函数。头文件通常包含了库提供的类、函数、宏等的声明,是C++编程中的重要组成部分。 CMakeLists.txt文件则是一个用于CMake构建系统的脚本文件,CMake是一个跨平台的自动化构建系统,它使用一个名为CMakeLists.txt的文件来配置项目的构建过程。在这个文件中,定义了项目构建所需的库文件、源代码文件以及构建项目所需的其他配置信息。 lib文件夹包含编译后的库文件,这些库文件是二进制格式的,可以直接被链接到其他应用程序中使用。在Windows系统中,这些文件可能包括.dll文件,在Unix-like系统中,通常是.so文件。通过这些编译好的库文件,开发者可以轻松地在自己的项目中实现串口通信功能。 pic文件夹可能包含用于程序开发的一些图片或图表资源,这些资源通常用于文档说明或者程序的界面设计中。 .travis.yml文件是基于Travis CI的配置文件,Travis CI是一个持续集成服务,它可以帮助开发者自动运行测试,确保代码在提交到版本控制系统之前保持在可工作的状态。开发者可以通过配置.travis.yml文件来自动化测试过程。 cserialport-config.cmake.in文件是CMake配置文件的模板,它可以在构建过程中被CMake工具使用,以便生成适应当前构建环境的cserialport-config.cmake文件。该文件用于提供关于如何找到CSerialPort库的信息,以及如何正确链接到库的指令。 .github文件夹通常包含了与GitHub平台相关的配置文件,如工作流配置、贡献指南等。这些文件有助于开发者管理他们的开源项目,包括代码托管、问题跟踪和版本控制等。 .gitattributes文件用于配置Git的仓库属性,它定义了在不同操作系统中的换行符处理方式,以及控制文件的其他行为。 .clang-format文件是一个用于源代码格式化的配置文件,Clang-Format是LLVM项目的一部分,它可以根据用户的配置来自动格式化C++代码,以保证代码风格的一致性。 doc文件夹包含项目文档,这些文档可能是源代码的注释、用户手册、API文档等,它们是开发者了解如何使用该库的重要参考资料。 这个名为“串口通信助手-CSerialPort-0”的软件包是一个功能强大的串口通信库,它为开发者提供了一整套串口通信的解决方案,包括通信协议的实现、数据的读写操作、以及与操作系统底层通信的接口。开发者可以利用这个库快速构建起自己的串口通信程序,大大降低开发难度和开发周期。
2025-11-13 13:37:56 86.23MB 串口通信
1
一个用于VC串口开发的工具类。简单实用。做串口开发的童鞋不用再头疼了,工具类可以直接使用。注意是vc++版本
2024-10-29 10:40:18 8KB windows串口
1
该应用程序是基于CSerialPort进行的MFC串口通信开发,压缩包内有可执行文件和源代码,下载后可用VS2010打开,可直接运行。
2024-04-14 18:43:03 43.06MB 串口通信
1
一个串口CserialPort类,很好用得。避免对底层API的调用,使用起来还是很方便的。,
2023-04-28 14:26:27 4KB 串口类
1
CSerialPort First Version by Remon Spekreijse on 2000-02-08 http://www.codeguru.com/cpp/i-n/network/serialcommunications/article.php/c2483/A-communication-class-for-serial-port.htm Second Version by mrlong on 2007-12-25 https://code.google.com/p/mycom/ 增加 ClosePort 增加 WriteToPort 两个方法 增加 SendData 与 RecvData 方法 by liquanhai on 2011-11-04 http://blog.csdn.net/liquanhai/article/details/4955253 增加 ClosePort 中交出控制权,防止死锁问题 by liquanhai on 2011-11-06 http://blog.csdn.net/liquanhai/article/details/6941574 增加 ReceiveChar 中防止线程死锁 by viruscamp on 2013-12-04 https://github.com/viruscamp/CSerialPort 增加 IsOpen 判断是否打开 修正 InitPort 中 parity Odd Even 参数取值错误 修改 InitPort 中 portnr 取值范围,portnr>9 时特殊处理 取消对 MFC 的依赖,使用 HWND 替代 CWnd,使用 win32 thread 函数而不是 MFC 的 增加用户消息编号自定义,方法来自 CnComm by itas109 on 2014-01-10 http://blog.csdn.net/itas109/article/details/18358297 解决COM10以上端口无法显示的问题 扩展可选择端口,最大值MaxSerialPortNum可以自定义 添加QueryKey()和Hkey2ComboBox两个方法,用于自动查询当前有效的串口号。 by liquanhai on 2014-12-18 增加一些处理措施,主要是对减少CPU占用率 by itas109 on 2016-05-07 http://blog.csdn.net/itas109 修复每次打开串口发送一次,当串口无应答时,需要关闭再打开或者接收完数据才能发送的问题。 解决办法:在m_hEventArray中调整m_hWriteEvent的优先级高于读的优先级。CommThread(LPVOID pParam)函数中读写的位置也调换。 参考:http://zhidao.baidu.com/link?url=RSrbPcfTZRULFFd2ziHZPBwnoXv1iCSu_Nmycb_yEw1mklT8gkoNZAkWpl3UDhk8L35DtRPo5VV5kEGpOx-Gea 修复停止位在头文件中定义成1导致SetCommState报错的问题,应为1对应的停止位是1.5。UINT stopsbits = ONESTOPBIT switch(stopbits)和switch(parity)增加默认情况,增强程序健壮性 by itas109 on 2016-06-22 http://blog.csdn.net/itas109 增加ReceiveStr方法,用于接收字符串(接收缓冲区有多少字符就接收多少字符)。 解决ReceiveChar只能接收单个字符的问题。 by itas109 on 2016-06-29 http://blog.csdn.net/itas109 解决RestartMonitoring方法和StopMonitoring方法命令不准确引起的歧义,根据实际作用。 将RestartMonitoring更改为ResumeMonitoring,将StopMonitoring更改为SuspendMonitoring。 增加IsThreadSuspend方法,用于判断线程是否挂起。 改进ClosePort方法,增加线程挂起判断,解决由于线程挂起导致串口关闭死锁的问题。 增加IsReceiveString宏定义,用于接收时采用单字节接收还是多字节接收 by itas109 on 2016-08-02 http://blog.csdn.net/itas109 https://github.com/itas109 改进IsOpen方法,m_hComm增加INVALID_HANDLE_VALUE的情况,因为CreateFile方法失败返回的是INVALID_HANDLE_VALUE,不是NULL 改进ClosePort方法:增加串口句柄无效的判断(防止关闭死锁);m_hWriteEvent不使用CloseHandle关闭 改进CommThread、ReceiveChar、ReceiveStr和WriteChar方法中异常处理的判断,增加三种判断:串口打开失败(error code:ERROR_INVALID_HANDLE)、连接过程中非法断开(error code:ERROR_BAD_COMMAND)和拒绝访问(error code:ERROR_ACCESS_DENIED) 采用安全函数sprintf_s和strcpy_s函数替换掉sprintf和strcpy 改进QueryKey方法,用于查询注册表的可用串口值,可以搜索到任意的可用串口 改进InitPort方法,串口打开失败,增加提示信息:串口不存在(error code:ERROR_FILE_NOT_FOUND)和串口拒绝访问(error code:ERROR_ACCESS_DENIED) 加入viruscamp 取消对 MFC 的依赖 改进InitPort方法,如果上次串口是打开,再次调用InitPort方法,关闭串口需要做一定的延时,否则有几率导致ERROR_ACCESS_DENIED拒绝访问,也就是串口占用问题 初始化默认波特率修改为9600 修复一些释放的BUG 规范了一些错误信息,参考winerror.h -- error code definitions for the Win32 API functions 删除SendData和RecvData方法 by itas109 on 2016-08-10 http://blog.csdn.net/itas109 https://github.com/itas109 改进ReceiveStr方法,comstat.cbInQue = 0xcccccccc的情况(如串口异常断开),会导致RXBuff初始化失败 by itas109 on 2017-02-14 http://blog.csdn.net/itas109 https://github.com/itas109 兼容ASCII和UNICODE编码 ReceiveStr函数中发送函数SendMessage的第二个参数采用结构体形式,包括portNr串口号和bytesRead读取的字节数,可以处理16进制的时候0x00截断问题 精简不必要的函数SendData和RecvData 尽量的取消对 MFC 的依赖,Hkey2ComboBox函数暂时保留 其他小问题修改 博客:blog.csdn.net/itas109 Email:itas109@qq.com
2022-11-21 15:08:15 266KB CSerialPort 串口类 串口
1
新增功能 * ★修复不能连续发送的问题 ★ fix can not continue send error * ★一次性写入尽可能多的数据到串口 ★ try best to send mutil data once in WriteChar funtion * 修复BYTE内存设置的问题 fix BYTE memset error * 在构造函数中初始化和释放临界区 initialize and delete critical section in Constructor * 精简代码 其他: 博客:blog.csdn.net/itas109 Email:itas109@qq.com
2022-11-11 01:04:35 484KB CSerialPort 串口 串口类
1
自己在前人的基础上更改,增加了线程关闭功能,能够彻底关闭串口,数据多次发送都可,串口使用完毕后可关闭
2022-11-08 09:15:09 10KB CSerialPort
1
PDF文档,基于CSerialPort类实现多线程的串口通信
2022-08-29 18:20:59 192KB CSerialPort 多线程
1
CSerialPort First Version by Remon Spekreijse on 2000-02-08 http://www.codeguru.com/cpp/i-n/network/serialcommunications/article.php/c2483/A-communication-class-for-serial-port.htm Second Version by mrlong on 2007-12-25 https://code.google.com/p/mycom/ 增加 ClosePort 增加 WriteToPort 两个方法 增加 SendData 与 RecvData 方法 by liquanhai on 2011-11-04 http://blog.csdn.net/liquanhai/article/details/4955253 增加 ClosePort 中交出控制权,防止死锁问题 by liquanhai on 2011-11-06 http://blog.csdn.net/liquanhai/article/details/6941574 增加 ReceiveChar 中防止线程死锁 by viruscamp on 2013-12-04 https://github.com/viruscamp/CSerialPort 增加 IsOpen 判断是否打开 修正 InitPort 中 parity Odd Even 参数取值错误 修改 InitPort 中 portnr 取值范围,portnr>9 时特殊处理 取消对 MFC 的依赖,使用 HWND 替代 CWnd,使用 win32 thread 函数而不是 MFC 的 增加用户消息编号自定义,方法来自 CnComm by itas109 on 2014-01-10 http://blog.csdn.net/itas109/article/details/18358297 解决COM10以上端口无法显示的问题 扩展可选择端口,最大值MaxSerialPortNum可以自定义 添加QueryKey()和Hkey2ComboBox两个方法,用于自动查询当前有效的串口号。 by liquanhai on 2014-12-18 增加一些处理措施,主要是对减少CPU占用率 by itas109 on 2016-05-07 http://blog.csdn.net/itas109 修复每次打开串口发送一次,当串口无应答时,需要关闭再打开或者接收完数据才能发送的问题。 解决办法:在m_hEventArray中调整m_hWriteEvent的优先级高于读的优先级。CommThread(LPVOID pParam)函数中读写的位置也调换。 参考:http://zhidao.baidu.com/link?url=RSrbPcfTZRULFFd2ziHZPBwnoXv1iCSu_Nmycb_yEw1mklT8gkoNZAkWpl3UDhk8L35DtRPo5VV5kEGpOx-Gea 修复停止位在头文件中定义成1导致SetCommState报错的问题,应为1对应的停止位是1.5。UINT stopsbits = ONESTOPBIT switch(stopbits)和switch(parity)增加默认情况,增强程序健壮性 by itas109 on 2016-06-22 http://blog.csdn.net/itas109 增加ReceiveStr方法,用于接收字符串(接收缓冲区有多少字符就接收多少字符)。 解决ReceiveChar只能接收单个字符的问题。 by itas109 on 2016-06-29 http://blog.csdn.net/itas109 解决RestartMonitoring方法和StopMonitoring方法命令不准确引起的歧义,根据实际作用。 将RestartMonitoring更改为ResumeMonitoring,将StopMonitoring更改为SuspendMonitoring。 增加IsThreadSuspend方法,用于判断线程是否挂起。 改进ClosePort方法,增加线程挂起判断,解决由于线程挂起导致串口关闭死锁的问题。 增加IsReceiveString宏定义,用于接收时采用单字节接收还是多字节接收 by itas109 on 2016-08-02 http://blog.csdn.net/itas109 https://github.com/itas109 改进IsOpen方法,m_hComm增加INVALID_HANDLE_VALUE的情况,因为CreateFile方法失败返回的是INVALID_HANDLE_VALUE,不是NULL 改进ClosePort方法:增加串口句柄无效的判断(防止关闭死锁);m_hWriteEvent不使用CloseHandle关闭 改进CommThread、ReceiveChar、ReceiveStr和WriteChar方法中异常处理的判断,增加三种判断:串口打开失败(error code:ERROR_INVALID_HANDLE)、连接过程中非法断开(error code:ERROR_BAD_COMMAND)和拒绝访问(error code:ERROR_ACCESS_DENIED) 采用安全函数sprintf_s和strcpy_s函数替换掉sprintf和strcpy 改进QueryKey方法,用于查询注册表的可用串口值,可以搜索到任意的可用串口 改进InitPort方法,串口打开失败,增加提示信息:串口不存在(error code:ERROR_FILE_NOT_FOUND)和串口拒绝访问(error code:ERROR_ACCESS_DENIED) 加入viruscamp 取消对 MFC 的依赖 改进InitPort方法,如果上次串口是打开,再次调用InitPort方法,关闭串口需要做一定的延时,否则有几率导致ERROR_ACCESS_DENIED拒绝访问,也就是串口占用问题 初始化默认波特率修改为9600 修复一些释放的BUG 规范了一些错误信息,参考winerror.h -- error code definitions for the Win32 API functions 删除SendData和RecvData方法 博客:blog.csdn.net/itas109 Email:itas109@qq.com
2022-07-20 20:43:02 19KB CSerialPort ClosePort 串口类 串口
1