读书笔记——Windows核心编程(13)Windows内存体系结构

对于32位进程(0x0000 0000~0xFFFF FFFF),有4GB的地址空间。

每个进程都有自己专有的地址空间,当进程的各个线程运行时,它们只能访问属于该进程的内存。


这4GB其实是虚拟地址空间,不是物理存储器。

为了能够正常读写数据,需要把物理存储器分配或者映射到相应的地址空间,否则将发生访问违规错误(Access Violation)。


x86 32位 Windows虚拟地址空间的分区

空指针赋值分区  0x0000 0000——0x0000 FFFF (捕获空指针的赋值)

用户模式分区      0x0001 0000——0x7FFE FFFF

64KB禁入分区    0x7FFF 0000——0x7FFF FFFF

内核模式分区      0x8000 0000——0xFFFF FFFF


当系统创建一个进程并赋予它地址空间时,可用地址空间中的发部分都是闲置的或尚未分配的。


为使用这部分的的地址空间,要调VirtualAlloc分配其中的区域,这个操作被称为预订。(不再使用时,调用VirtualFree释放。)

分配的粒度为64K,起始地址为分配粒度的整数倍。系统会确保分配的大小正好是系统页面大小的整数倍。

x86系统的页面大小为4KB。


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值