在Linux系统上,c/c++
编程语言使用的指针占用的存储空间大小为4或者8个字节(
分别对应32位和64位cpu架构),
因此指针所能引用的虚拟内存范围是分别是4G或者4G*4G.
而事实上Linux操作系统将虚拟地址空间分成了两部分,
其中的低地址部分作为用户空间,高地址部分作为内核空间. 具体来说,对32系统来说,用户地址空间大小为3G(
Windows通常是2G),内核地址空间使用剩余的1G部分. 对64位系统, 用户地址限定在低128T范围, 内核空间地址限定在高128T部分,
两部分地址空间之间保留未用. 64位虚拟地址只有低48位是有效的.
查询一下Intel网站就可看到64位Intel cpu支持的内存多为几十G而已[2].

Linux X86架构虚拟内存分布[1]
单就64位Linux而言, 现在只利用了很小一部分虚拟地址空间. 硬件上cpu总线地址也只使用了约40位(使用cat /proc/cpuinfo命令即可看到cpu信息),
#cat /proc/cpuinfo
...
processor : 0
address sizes : 40 bits physical, 48 bits virtual
[1] <<The Definitive Guide to the Xen Hypervisor>>
[2 http://ark.intel.com/products/
...
