头文件被修改导致一个难以理解、难以调试的错误
最近在使用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控制起来,不允许修改才更可靠一点。
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控制起来,不允许修改才更可靠一点。