使用 pipe() 和 fdopen() 将数据从 Python 脚本传递到 Windows 中的C++应用程序
Use pipe() and fdopen() to pass data from Python script to C++ application in Windows
我们有一些Linux/macOS应用程序,它可以通过传递文件描述符并从中读取数据来与外部世界进行通信。通常这样做是为了传递stdin/stdout描述符,但是我们使用pipe(),这工作得很好。除了MinGW/Windows。 在Windows下执行相同工作的推荐方法是什么?传递整个文件句柄,或者有模拟类似小整数的描述符的好方法?
在Windows中,C文件描述符在保留字段中STARTUPINFO
记录的过程中继承cbReserved2
和lpReserved2
。该协议未记录,但源代码与Visual C++一起分发。使用此功能的 C 函数包括_[w]spawn
系列函数和[_w]system
。(但是,[_w]system
函数在这方面通常没有用,因为只有直接的 cmd.exe 进程继承父级的文件描述符。CMD 不会将它们传递给子进程。
在 Python 2.7 中,os.pipe
是通过调用CreatePipe
来实现的,它返回管道读写端的不可继承文件句柄。然后通过_open_osfhandle
用可继承的文件描述符手动包装这些句柄,但底层操作系统句柄仍然是不可继承的。若要解决此问题,请通过os.dup
复制文件描述符,这会在内部复制可继承的文件句柄,然后关闭源文件描述符。例如:
pread, pwrite = os.pipe()
pwrite_child = os.dup(pwrite)
os.close(pwrite)
Python 的subprocess
模块通常是创建子进程的首选方法。但是,在这种情况下我们不能使用subprocess
,因为它不支持通过STARTUPINFO
(*) 继承文件描述符。下面是一个改用os.spawnv
的示例:
rc = os.spawnv(os.P_WAIT, 'path/to/spam.exe', ['spam', 'arg1', 'arg2'])
(*) Windows Python 内部使用 C 运行时文件 API 是一个尴尬的情况(例如_wopen
、_read
、_write
),但在某些地方不支持C文件描述符。它应该咬紧牙关,直接将Windows文件API与操作系统文件句柄一起使用,那么它至少是一致的。
- 在VS代码中交叉编译Windows与Linux上的MinGW的SDL程序
- 在Linux for Windows上编译C++代码时出错
- 在Windows上用C++裁剪HBITMAP
- C++ Windows 驱动程序MSB3030无法复制该文件,因为它找不到
- 如何加载(或映射)文件部分的最大大小,但适合在Windows上的RAM
- std::threads可以从Windows DLL中的全局变量创建/销毁吗?
- 当我编译webrtc服务器时,Windows上只支持clang-cl
- 为什么在Windows上的VS 2019和Clang 9中"size_t"在没有标题的情况下工作
- Windows/Cygwin - 不能使用 pybind11 - 犯错误
- Windows 10-使用gtkmm-3.0库和g++[包括再现]的分段故障
- 在Windows中以.exe的形式运行c++
- 为什么包含windows.h会产生语法错误,从而阻止类的实例化?(C2146,C2065)
- 无法在windows控制台中为C++程序提供必要的输入
- 在Windows中查找扬声器输出的当前音量级别
- Windows.h与GLFW.h的接口
- 在 Windows 上,是否可以让 dll 在不使用 PATH 环境变量的情况下在另一个文件夹中查找依赖项?
- 在Linux和C++中的Windows上,散列字符串值会产生不同的输出
- Active Directory:从网络服务帐户下运行的Windows服务调用ADsOpenObject时失败
- c++17文件系统::recursive_directory迭代器()在mac上没有给出这样的目录,但在windows上
- 无法使用Qt Creator在Windows中构建yaml-cpp