头文件被修改导致一个难以理解、难以调试的错误

最近在使用vc++2005调试一个ppc项目时,发现如下语句执行始终出错

HBITMAP hb = LoadBitmap(g_hInst,MAKEINTRESOURCE(IDB_BITMAP1));

在resource.h中IDB_BITMAP1定义为

#define IDB_BITMAP1                     101

在需要的地方都包含了resource.h,这个错误让我莫名奇妙。

使用GetLastError()查看错误代码,发现始终是ERROR_RESOURCE_NAME_NOT_FOUND,找不到资源名

但是使用exescope查看,我的dll文件确实是存在该资源的

使用如下方式

HBITMAP hb = LoadBitmap(g_hInst, _T("#101"));

调用时,结果是正确的,证明确实资源存在,资源号也正确。

那么只有可能是MAKEINTRESOURCE(IDB_BITMAP1)有问题了,而它是vc中的一个宏,不应该存在问题

在winuser.h中找到这个宏的定义,它被定义为
#define MAKEINTRESOURCEA(i) (LPSTR)((DWORD)((WORD)(i)))
#define MAKEINTRESOURCEW(i) (LPWSTR)((DWORD)((WORD)(32456)))
#ifdef UNICODE
#define MAKEINTRESOURCE  MAKEINTRESOURCEW
#else
#define MAKEINTRESOURCE  MAKEINTRESOURCEA
#endif // !UNICODE


原来是我一次冒失的修改了#define MAKEINTRESOURCEW(i) (LPWSTR)((DWORD)((WORD)(32456)))

应该是#define MAKEINTRESOURCEW(i) (LPWSTR)((DWORD)((WORD)(i)))

这条宏在头文件中出现,在代码编译时会正常展开,而不会有任何错误提示,可惜我一直没往这方面想,而是花了一晚上的时间反复调试和在网上搜索解决办法。

引申出一个问题,这种头文件应该被ide控制起来,不允许修改才更可靠一点。

posted on 2007-07-19 09:49  yoyolion  阅读(962)  评论(0编辑  收藏  举报