【坑】winsock2.h和windows.h的include顺序
给qt工程添加一个日志模块,该模块只有一个头文件,顺手就把这个头文件放在cpp的顶部include了,结果一编译出来一堆错误,仔细一看,都是些winsock2相关的错误。
当时就有点纳闷了,这个新增的头文件并没有使用winsock2啊,为啥会出这种问题,把错误信息百度一下,看来有很多人也遇到了。
原来是头文件的包含顺序问题,日志的头文件包含了windows.h,而日志后的QT的网络相关的头文件包含了winsock2.h,从而导致出了问题,只需要winsock2.h的顺序在windows.h之前就行了,解决方案很简单,后续统一都先包含qt的头文件,然后再是自己的头文件。
追究起来,这就是头文件的反复包含问题,windows.h包含了winsock.h,而winsock和winsock2只能2选1,都定义了同样的宏 WINSOCKAPI ,如果windows.h先于winsock2.h,那么导致使用了winsock.h,定义了 WINSOCKAPI ,从而后续winsock2.h的内容都不会被添加进来,进而导致编译错误。
当然,解决的方式不单单只有调整这个包含顺序,也可以通过定义WIN32_LEAN_AND_MEAN让windows.h不包含winsock.h而解决(VC工程默认生成的stdafx.h有这个宏定义,QT则没有,所以用QT的时候反而会遇到这些问题)。