什么是Windows相当于sys/select.h和termios.h中定义的功能
我有一个在linux中的应用程序,它被成功编译。
我想在Windows中运行相同的程序。 但编译会产生与头文件相关的以下错误。 >找不到sys / select.h 如何解决这个问题?
Windows API在结构上和风格上与Unix所提供的任何风格的系统调用和库例程的混合都非常不同。
termio.h中 Windows使用与任何* nix系统非常不同的型号执行终端I / O。因此,真的没有直接相当于termio.h标题及其朋友。 您想在MSDN上阅读Windows Communications Resources。 有些事要了解更多关于包括: > DCB结构 一般来说,您会发现,您需要直接处理Windows API,因为stdio会在进行设备I / O时增加混乱。 select.h 没有直接等同于Unix select(2)系统调用。 在Windows中,许多内核对象可以处于信令状态或非信号状态,并且可以使用发送对象的动作来释放调用 如果您需要等待正在处理窗口消息的线程中的事件,那么您应该使用 请阅读MSDN文章Using Synchronization上的Windows同步原语。 然而,Windows内置了几种异步I / O,可以通过改变设计来替代select()的需要。两者都将需要广泛使用不能与C stdio库结合使用的功能。 MSDN有几篇关于I / O技术的文章,以及许多例子: > I/O Concepts 请注意,关于Windows如何工作的大部分信息都分散在概述文章和API函数和结构的参考资料的备注部分中。这可以给人的印象是,一读就没有完全记录。 移植Cygwin 另一种方法是使用Cygwin做端口。它通过Windows API提供大部分POSIX层。但是,您将得到一个依赖于Cygwin DLL的应用程序,该应用程序是GPL,除非您从其购买商业使用许可证。使用Cygwin可以很方便地获得一个适用于没有Unix体验的Windows用户的应用程序,因为有关两个系统的设置和使用方式的许多其他假设有所不同。 Cygwin已经做了相当大的努力来构建一个在Windows上运行的select()的实现,给出了不同的打开文件描述符的混合。这个努力是described in the User’s Guide。 请注意,如果在Cygwin环境中完成,则只会记录和支持Cygwin的构建。通常仅将Cygwin的bin放在Windows PATH上并通过命令提示符工作是不够的。您真的需要启动Cygwin的bash构建并从中编译,以便所有内容都使用相同的Cygwin风格的安装点和模拟的Unix文件结构。 将Cygwin头文件与第三方工具头文件混合是一个确定的疯狂之路。 编辑:我重新排列了一些,并添加了一些材料以回应评论。 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |