编程语言使用的指针占用的存储空间大小为4或者8个字节(分别对应32位和64位cpu架构),因此指针所能引用的虚拟内存范围是分别是4G或者4G*4G.而事实上Linux操作系统将虚拟地址空间分成了两部分,其中的低地址部分作为用户空间,高地址部分作为内核空间. 具体来说,对32系统来说,用户地址空间大小为3G(Windows通常是2G),内核地址空间使用剩余的1G部分. 对64位系统, 用户地址限定在低128T范围, 内核空间地址限定在高128T部分,两部分地址空间之间保留未用. 64位虚拟地址只有低48位是有效的.
![Linux X86架构虚拟内存分布](https://img-my.csdn.net/uploads/201212/15/1355560870_5289.png)
Linux X86架构虚拟内存分布[1]
单就64位Linux而言, 现在只利用了很小一部分虚拟地址空间. 硬件上cpu总线地址也只使用了约40位(使用cat /proc/cpuinfo命令即可看到cpu信息),查询一下Intel网站就可看到64位Intel cpu支持的内存多为几十G而已[2].
#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/65525/Intel-Core-i7-3770T-Processor-8M-Cache-up-to-3_70-GHz
...
![](https://mail.google.com/mail/u/0/images/cleardot.gif)