编程经验:一个由<Windows.h>引起的bug~

1. 问题描述

最近遇到一个莫名其妙的bug,上网查找,没有找到正确的解决办法,难道大家都没遇到?于是我说一说自己是怎么解决的。

我用的是VS2010,一个解决方案下,添加了多个他人的项目,各个项目配置都使用了库文件(A.lib),编译,唯独其中一个项目,出现了如下错误提示:

错误         26     error C2040: “LPCH”:“int”与“int *”的间接寻址级别不同     c:\program files (x86)\microsoftsdks\windows\v7.0a\include\winbase.h         3539

错误         32     error C2059: 语法错误:“)”        c:\program files (x86)\microsoftsdks\windows\v7.0a\include\winbase.h    3564

错误         37     error C2061: 语法错误: 标识符“LPCH”  c:\program files (x86)\microsoftsdks\windows\v7.0a\include\winbase.h         14149

错误         36     error C2061: 语法错误: 标识符“PLONG”        c:\program files (x86)\microsoftsdks\windows\v7.0a\include\winbase.h         4990

错误         50     error C2061: 语法错误: 标识符“PLONG”        c:\program files (x86)\microsoftsdks\windows\v7.0a\include\winreg.h   742

错误         51     error C2061: 语法错误: 标识符“PLONG”        c:\program files (x86)\microsoftsdks\windows\v7.0a\include\winreg.h   751

错误         1       error C2143: 语法错误 : 缺少“;”(在“*”的前面)        c:\program files (x86)\microsoftsdks\windows\v7.0a\include\winnt.h     424

错误         6       error C2143: 语法错误 : 缺少“;”(在“*”的前面)        c:\program files (x86)\microsoftsdks\windows\v7.0a\include\winnt.h     489

错误         9       error C2143: 语法错误 : 缺少“;”(在“*”的前面)        c:\program files (x86)\microsoftsdks\windows\v7.0a\include\winnt.h     490

错误         24     error C2143: 语法错误 : 缺少“;”(在“__stdcall”的前面)   c:\program files (x86)\microsoftsdks\windows\v7.0a\include\winbase.h         3539

错误         28     error C2146: 语法错误: 缺少“)”(在标识符“NewEnvironment”的前面)   c:\program files (x86)\microsoftsdks\windows\v7.0a\include\winbase.h         3564

错误         52     error C2371: “SHORT”: 重定义;不同的基类型    c:\program files (x86)\microsoftsdks\windows\v7.0a\include\wtypes.h  382

错误         31     error C2440: “初始化”: 无法从“int *”转换为“BOOL”  c:\program files (x86)\microsoftsdks\windows\v7.0a\include\winbase.h         3564

错误         35     error C2440: “初始化”: 无法从“int *”转换为“BOOL”  c:\program files (x86)\microsoftsdks\windows\v7.0a\include\winbase.h         3582

错误         34     error C2491: “FreeEnvironmentStringsA”: 不允许 dllimport数据 的定义 c:\program files (x86)\microsoftsdks\windows\v7.0a\include\winbase.h         3582

错误         30     error C2491: “SetEnvironmentStringsA”: 不允许 dllimport数据 的定义   c:\program files (x86)\microsoftsdks\windows\v7.0a\include\winbase.h         3564

错误         48     error C2665: “InterlockedCompareExchange”: 2 个重载中没有一个可以转换所有参数类型   c:\program files(x86)\microsoft sdks\windows\v7.0a\include\winbase.h       15393

错误         49     error C2665: “InterlockedCompareExchange”: 3 个重载中没有一个可以转换所有参数类型   c:\program files(x86)\microsoft sdks\windows\v7.0a\include\winbase.h       15404

错误         40     error C2665: “InterlockedDecrement”: 2 个重载中没有一个可以转换所有参数类型        c:\program files(x86)\microsoft sdks\windows\v7.0a\include\winbase.h       15262

错误         41     error C2665: “InterlockedDecrement”: 3 个重载中没有一个可以转换所有参数类型        c:\program files(x86)\microsoft sdks\windows\v7.0a\include\winbase.h       15271

错误         42     error C2665: “InterlockedExchange”: 2 个重载中没有一个可以转换所有参数类型  c:\program files(x86)\microsoft sdks\windows\v7.0a\include\winbase.h       15294

错误         43     error C2665: “InterlockedExchange”: 3 个重载中没有一个可以转换所有参数类型  c:\program files(x86)\microsoft sdks\windows\v7.0a\include\winbase.h       15304

错误         44     error C2665: “InterlockedExchangeAdd”: 2 个重载中没有一个可以转换所有参数类型    c:\program files(x86)\microsoft sdks\windows\v7.0a\include\winbase.h       15328

错误         45     error C2665: “InterlockedExchangeAdd”: 2 个重载中没有一个可以转换所有参数类型    c:\program files(x86)\microsoft sdks\windows\v7.0a\include\winbase.h       15338

错误         46     error C2665: “InterlockedExchangeAdd”: 3 个重载中没有一个可以转换所有参数类型    c:\program files(x86)\microsoft sdks\windows\v7.0a\include\winbase.h       15348

错误         47     error C2665: “InterlockedExchangeAdd”: 3 个重载中没有一个可以转换所有参数类型    c:\program files(x86)\microsoft sdks\windows\v7.0a\include\winbase.h       15358

错误         38     error C2665: “InterlockedIncrement”: 2 个重载中没有一个可以转换所有参数类型          c:\program files(x86)\microsoft sdks\windows\v7.0a\include\winbase.h       15231

错误         39     error C2665: “InterlockedIncrement”: 3 个重载中没有一个可以转换所有参数类型          c:\program files(x86)\microsoft sdks\windows\v7.0a\include\winbase.h       15240

错误         12     error C2733: 不允许重载函数“_bittest”的第二个 C 链接   c:\program files (x86)\microsoftsdks\windows\v7.0a\include\winnt.h     3656

错误         13     error C2733: 不允许重载函数“_bittestandcomplement”的第二个 C 链接         c:\program files (x86)\microsoftsdks\windows\v7.0a\include\winnt.h     3662

错误         15     error C2733: 不允许重载函数“_bittestandreset”的第二个 C 链接    c:\program files (x86)\microsoftsdks\windows\v7.0a\include\winnt.h     3674

错误         14     error C2733: 不允许重载函数“_bittestandset”的第二个 C 链接        c:\program files (x86)\microsoftsdks\windows\v7.0a\include\winnt.h     3668

错误         18     error C2733: 不允许重载函数“_InterlockedAnd16”的第二个 C 链接 c:\program files (x86)\microsoftsdks\windows\v7.0a\include\winnt.h     3770

错误         17     error C2733: 不允许重载函数“_interlockedbittestandreset”的第二个 C 链接  c:\program files (x86)\microsoftsdks\windows\v7.0a\include\winnt.h     3686

错误         16     error C2733: 不允许重载函数“_interlockedbittestandset”的第二个 C 链接      c:\program files (x86)\microsoftsdks\windows\v7.0a\include\winnt.h     3680

错误         19     error C2733: 不允许重载函数“_InterlockedCompareExchange16”的第二个 C 链接 c:\program files (x86)\microsoftsdks\windows\v7.0a\include\winnt.h   3777

错误         20     error C2733: 不允许重载函数“_InterlockedOr16”的第二个 C 链接   c:\program files (x86)\microsoftsdks\windows\v7.0a\include\winnt.h     3783

错误         2       error C4430: 缺少类型说明符 - 假定为 int。注意: C++ 不支持默认 int      c:\program files (x86)\microsoftsdks\windows\v7.0a\include\winnt.h     424

错误         3       error C4430: 缺少类型说明符 - 假定为 int。注意: C++ 不支持默认 int      c:\program files (x86)\microsoftsdks\windows\v7.0a\include\winnt.h     424

错误         4       error C4430: 缺少类型说明符 - 假定为 int。注意: C++ 不支持默认 int      c:\program files (x86)\microsoftsdks\windows\v7.0a\include\winnt.h     424

错误         5       error C4430: 缺少类型说明符 - 假定为 int。注意: C++ 不支持默认 int      c:\program files (x86)\microsoftsdks\windows\v7.0a\include\winnt.h     424

错误         7       error C4430: 缺少类型说明符 - 假定为 int。注意: C++ 不支持默认 int      c:\program files (x86)\microsoftsdks\windows\v7.0a\include\winnt.h     489

错误         8       error C4430: 缺少类型说明符 - 假定为 int。注意: C++ 不支持默认 int      c:\program files (x86)\microsoftsdks\windows\v7.0a\include\winnt.h     489

错误         10     error C4430: 缺少类型说明符 - 假定为 int。注意: C++ 不支持默认 int      c:\program files (x86)\microsoftsdks\windows\v7.0a\include\winnt.h     490

错误         11     error C4430: 缺少类型说明符 - 假定为 int。注意: C++ 不支持默认 int      c:\program files (x86)\microsoftsdks\windows\v7.0a\include\winnt.h     490

错误         25     error C4430: 缺少类型说明符 - 假定为 int。注意: C++ 不支持默认 int      c:\program files (x86)\microsoftsdks\windows\v7.0a\include\winbase.h         3539

错误         27     error C4430: 缺少类型说明符 - 假定为 int。注意: C++ 不支持默认 int      c:\program files (x86)\microsoftsdks\windows\v7.0a\include\winbase.h         3542

2. 问题原因

其实完全可以忽略最后几条错误,每次找bug,都应该重点关注最开始的几个,后面的bug,很可能是编译器不够完美的原因。经过观察,发现问题出现在winbase.h文件,这就奇怪了,这个头文件是系统文件,不会有任何问题,于是就查找winbase.h的位置,发现其在windows.h中被包含过,而后者是经常被使用的头文件。

windows.h中的相关代码如下所示:

#include
<windef.h>

#include
<winbase.h>

#include
<wingdi.h>

#include
<winuser.h>

#if !defined(_MAC) ||defined(_WIN32NLS)

#include
<winnls.h>

#endif

#ifndef
_MAC

#include
<wincon.h>

#include
<winver.h>

#endif

#if !defined(_MAC) ||defined(_WIN32REG)

#include
<winreg.h>

#endif

#ifndef
_MAC

#include
<winnetwk.h>

#endif

此时,问题已经显而易见了,肯定是windows.h与winbase.h冲突的原因,更进一步,原因是winbase.h被重复包含了。

3. 问题解决

他人的项目中,肯定引用了winbase.h头文件,不能改他人的项目,那只能改正自己的A.lib了,结果发现A.lib中的头文件,包含了windows.h,赶紧将其放入cpp文件中,重新编译,通过!!!

或者对A.lib中的windows.h,进行预编译限制,也可以解决。

4.总结

1). 看bug就看最开始的几个,前面几个解决了,后面的bug往往自动消失。

2). 不要怀疑系统文件,千锤百炼的东西,不会轻易有问题,问题出在自己身上。

3). 这样莫名其妙的错误,往往是头文件被重复包含的原因,仔细查看头文件即可。查找办法,肯定是先看看出错的文件在那个文件中被包含过,一层一层的去找。

时间: 2024-08-05 15:25:23

编程经验:一个由<Windows.h>引起的bug~的相关文章

Windows网络编程经验小结

转自:CSDN网友的强贴,其ID:gdy119 (夜风微凉) 1. 如果在已经处于 ESTABLISHED状态下的socket(一般由端口号和标志符区分)调用closesocket(一般不会立即关闭而经历TIME_WAIT的过程)后想继续重用该socket: BOOL bReuseaddr=TRUE; setsockopt(s,SOL_SOCKET ,SO_REUSEADDR,(const char*)&bReuseaddr,sizeof(BOOL)); 2. 如果要已经处于连接状态的soket

【windows核心编程】一个API拦截的例子

API拦截 修改PE文件导入段中的导入函数地址 为 新的函数地址 这涉及PE文件格式中的导入表和IAT,PE文件中每个隐式链接的DLL对应一个IMAGE_IMPORT_DESCRIPTOR描述符结构,而每个IMAGE_IMPORT_DESCRIPTOR结构中的FirstThunk指向一个IMAGE_THUNK_DATA结构数组的首地址. 在这个IAMGE_THUNK_DATA数组中,每一项对应一个该DLL模块的导入函数(对使用该DLL模块的PE文件来说是 导入).  结构大致如下 拦截某DLL模

JAVA web编程经验之: 一个请求一个事务

对于一个web请求,你会开启几个事务呢? 或许你没注意过吧. 又或许你不会对代码,性能要求太高,所以.... 一个请求一个事务, 因为一个事务往往和一个数据库连接关联, 如果开启了多个事务的话,也就意味着多个数据库连接, 性能不高吧? 前提 1.项目的代码结构分层如下: web层 ->  service层 -> infrastructure层(或DAO层) 2.所有事务都添加在 service层, 通过AOP(或其他类似的技术)实现 先看代码(一个Spring Controller 的调用代码

C++的XML编程经验――LIBXML2库使用指南[转]

C++的XML编程经验――LIBXML2库使用指南 写这篇文章的原因有如下几点:1)C++标准库中没有操作XML的方法,用C++操作XML文件必须熟悉一种函数库,LIBXML2是其中一种很优秀的XML库,而且它同时支持多种编程语言:2)LIBXML2库的Tutorial写得不太好,尤其是编码转换的部分,不适用于中文编码的转换:3)网上的大多数关于Libxml2的介绍仅仅是翻译了自带的资料,没有详细介绍如何在windows平台下进行编程,更很少提到如何解决中文问题. 基于以上几点原因,决定写一个在

Python/Numpy大数据编程经验

Python/Numpy大数据编程经验 1.边处理边保存数据,不要处理完了一次性保存.不然程序跑了几小时甚至几天后挂了,就啥也没有了.即使部分结果不能实用,也可以分析程序流程的问题或者数据的特点. 2. 及时用 del 释放大块内存.Python缺省是在变量范围(variablescope)之外才释放一个变量,哪怕这个变量在后面的代码没有再被用到,所以需要手动释放大的array. 注意所有对数组的引用都del之后,数组才会被del.这些引用包括A[2:]这样的view,即使np.split也只是

嵌入式C编程经验 之 全局变量猛于虎

/********************************************************************************* * Filename: 一线研发之声:嵌入式C编程经验 之 全局变量猛于虎 * Author:SedateFire          E-mail:[email protected] * Version:1.001                 Time: 2012-01-05 * key: 嵌入式  os-less  全局变量 

牢记20条编程经验

http://article.yeeyan.org/view/184220/150437 原文作者乔纳森·丹尼可(JonathanDanylko)是一位自由职业的Web架构师和程序员,编程经验已超过20年 1. 估算解决问题所需要的时间.不要怕,承认吧!我曾见过一些程序员为了解决一个特殊问题而坐在显示器前面8小时.为自己定一个时间限制吧,1小时.30分钟或甚至15分钟.如果在这期间你不能解决问题,那就去寻求帮助,或到网上找答案,而不是尝试去做“超级堆码员”. 2. 编程语言是一种语言,只是一种语

编程经验

所谓高手,就是说他在模仿的过程中不断比较自己写的东西和框架本身的差异,不断发现问题,想尽办法解决问题,思考得越多,你碰到的问题就会越多,这是一个正向循环,最终你的技术能力就会螺旋式的上升:而低手只会被动的等待问题,一旦问题自己觉得解决得差不多就放下了,这样自然就不会产生更多的问题,最终技术能力就始终停留在那个菜鸟阶段 1. 估算解决问题所需要的时间.不要怕,承认吧!我曾见过一些程序员为了解决一个特殊问题而坐在显示器前面8小时.为自己定一个时间限制吧,1小时.30分钟或甚至15分钟.如果在这期间你

用Qt写的一个仿Windows记事本程序

闲得无聊加上自己喜欢Qt所以就写了这样一个仿windows记事本的程序,全部功能经测试可用.Qt版本5.5+win7x64 其中有部分逻辑比较乱,大家多多交流 备用链接:https://github.com/piaodonkey/notepad .pro部分: #------------------------------------------------- # # Project created by QtCreator 2015-09-12T21:33:50 # #------------