gpt4 book ai didi

c++ - 在不打开端口的情况下确定设备是否连接/断开到 RS232 端口

转载 作者:行者123 更新时间:2023-11-30 01:32:58 27 4
gpt4 key购买 nike

我正在开发一个 C++ Win32 应用程序,如果设备已插入其中一个 RS232 端口,然后它是否已断开连接,我将尝试从根本上“自动检测”该应用程序。

检查连接的设备非常简单,因为我的用例允许我假设这个特定线程将是第一个尝试启动与端口通信的线程。我能够每分钟左右扫描一次可用端口,一旦我找到一个带有设备的端口,我就会标记该端口有一个设备,关闭该端口,然后设置一个事件,以便实际执行的过程使用设备知道它现在可以连接到该端口。

断开连接检测是我遇到麻烦的地方。当我扫描连接的设备时,我实际上可以将数据发送到端口以确保如果有设备,它就是我正在寻找的特定设备。但是一旦连接,该端口将已被其他进程打开,我无法再从检测线程打开该端口。所以我正在寻找一种方法,以“监听模式”或类似的方式打开端口,这样我就可以看到设备是否仍然存在。

我简单地遇到了一些关于观看 DSR 或 DTR 行之类的东西......但找不到更多或如何实际去做。

有什么建议吗?

编辑: 看来我需要再澄清一点...为了检测断开连接,我无法以任何方式将数据发送到 RS232 端口 . 另外,我不能假设另一个应用程序实际上打开了端口。该设备可能已物理连接,但没有打开连接......但我仍然不能冒险向它发送数据。我希望有一种方法可以检查该端口上是否还有电或类似的东西。

最佳答案

这取决于连接的硬件,当您断开硬件连接时,调制解调器状态寄存器是否会发生变化,但如果有,您可以使用 GetCommModemStatus() 检查 CTS 或 DSR 线路的状态。功能。

然而,问题是您需要一个 COM 端口的文件句柄来调用任何 API 函数,这在 CreateFile() 的文档中是独有的。状态:

The CreateFile function can create a handle to a communications resource, such as the serial port COM1. For communications resources, the dwCreationDisposition parameter must be OPEN_EXISTING, the dwShareMode parameter must be zero (exclusive access)

所以你不能打开COM端口来观察线路状态,而另一个进程已经打开端口进行通信。

有很多方法可以做到这一点,但它们需要一个驱动程序。 SysInternals 有 Portmon tool ,Google 搜索会发现一些公司销售用于在应用程序之间共享 COM 端口访问的软件,但据我所知,使用标准 API 不可能同时访问。

关于c++ - 在不打开端口的情况下确定设备是否连接/断开到 RS232 端口,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/757556/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com