我们经常会遇到在系统是64位,编译在32位下进行写代码,下边给出例子:
// 这个函数只在32位下边才进行调用
void SetExceptionPolicy()
{
BOOL os64 = FALSE;
// 判断系统是64位,还是32位
SYSTEM_INFO si;
GetNativeSystemInfo(&si);
// Display the contents of the SYSTEM_INFO structure.
TRACE("si.wProcessorArchitecture = %d\nPROCESSOR_ARCHITECTURE_AMD64 = %d\nPROCESSOR_ARCHITECTURE_IA64 = %d\n",
si.wProcessorArchitecture, PROCESSOR_ARCHITECTURE_AMD64, PROCESSOR_ARCHITECTURE_IA64);
if (si.wProcessorArchitecture == PROCESSOR_ARCHITECTURE_AMD64 || si.wProcessorArchitecture == PROCESSOR_ARCHITECTURE_IA64)
os64 = TRUE;
else
os64 = FALSE;
#ifdef _M_IX86
// 64的系统,32位编译下,才运行这个代码
if (os64)
{
#define PROCESS_CALLBACK_FILTER_ENABLED 0x1
typedef BOOL(WINAPI *GETPROCESSUSERMODEEXCEPTIONPOLICY)(__out LPDWORD lpFlags);
typedef BOOL(WINAPI *SETPROCESSUSERMODEEXCEPTIONPOLICY)(__in DWORD dwFlags);
HMODULE hKernel32 = LoadLibrary(_T("kernel32.dll"));
if (hKernel32 != NULL)
{
SETPROCESSUSERMODEEXCEPTIONPOLICY pfnSetProcessUserModeExceptionPolicy =
(SETPROCESSUSERMODEEXCEPTIONPOLICY)GetProcAddress(hKernel32, "SetProcessUserModeExceptionPolicy");
GETPROCESSUSERMODEEXCEPTIONPOLICY pfnGetProcessUserModeExceptionPolicy =
(GETPROCESSUSERMODEEXCEPTIONPOLICY)GetProcAddress(hKernel32, "GetProcessUserModeExceptionPolicy");
if (pfnSetProcessUserModeExceptionPolicy != NULL &&
pfnGetProcessUserModeExceptionPolicy != NULL)
{
DWORD dwFlags = 0;
if (pfnGetProcessUserModeExceptionPolicy(&dwFlags))
{
pfnSetProcessUserModeExceptionPolicy(dwFlags & ~PROCESS_CALLBACK_FILTER_ENABLED);
}
}
FreeLibrary(hKernel32);
}
}
#endif
/*
// 32位编译
#ifdef _M_IX86
#pragma comment(lib,"QDPay_mt.lib")
#endif // _M_IX86
// 64位编译
#ifdef _M_X64
#pragma comment(lib,"QDPay_mt64.lib")
#endif // _M_X64
*/
}