2012/4/27 Plain_Text <resat...@gmail.com> > > > > 从 C/C++ 程序员的角度来看,32位系统与64位系统的本质区别是什么?注意 > 这里说的是广义的32位和64位,而不特定指 i386, amd64. 是否是指针长度不一样? > 我现在这样区分两者: > > #if __SIZEOF_POINTER__ == 4 > /* 32位系统 */ > #elif __SIZEOF_POINTER__ == 8 > /* 64位系统 */ > #endif > > 这是 GCC 下的标准的做法吗?
要回答这个问题,首先你要弄清楚,你为什么要判断系统的类型?是想要针对64位 地址做优化呢,还是仅仅想使用64位数据类型? 现在已经有32,64,128位数据类型的自然支持,地址寄存器只有32位和64位这2种. 如果你需要区分32位地址和64位地址,那么就使用判断指针长度的做法,例如使用 __SIZEOF_POINTER__ 或 sizeof(void*) 或 __LP64__/__ILP32__ . 如果你只关心数据类型,可以判断 __SIZEOF_INT__ 或 __SIZEOF_LONG__ 或 __SIZEOF_LONG_LONG__ 或 __SIZEOF_SIZE_T__ 或 __SIZEOF_INT128__ 。 最简单的办法是,你可以直接使用 stdint.h 中定义的 [u]int(8|16|32|64)_t 数据类型. > 另外顺便问一下,在 Windows 下的 MSVC 里, > 该用什么宏来区分两者? Windows 似乎只支持i386, amd64, 应该容易应付。不过 > 最新的 Windows 8 好像也开始支持 MIPS 系统。 MSVC 比较简单,在 64 bit 系统中定义了 _WIN64,只要没有定义 _WIN64,就是 32 bit 系统. 对于 64 位的 x86 机器,定义了 _M_AMD64 (或者中立的名字 _M_X64). 对于 32 位的 x86 机器,定义了 _M_IX86 . MSVC 11 的测试版本我没有安装,因此不知道 MIPS 的预定义宏,你可以自己装装看看. 注意判断的时候要使用"不是64就视为32的逻辑",而不要使用"不是32就视为64的逻辑".