Win32之内存管理之虚拟内存跟物理内存

                   Win32之内存管理

一丶虚拟内存和物理内存

  我们知道每个应用程序都有自己独立的4GB空间.  假设A进程的 地址123 存储了10  那么B进程的123地址 存储了20

那么它们两个是互不影响的. 但是值是真实存在的. 而值是存储在物理内存的.如下图所示.

根据上图所示. 我们可以分清虚拟内存跟物理内存. 如果我们更改了物理内存的值.那么就会影响A进程或者B进程.

当然如果你学过内核驱动.就知道内核驱动读写就是你这个意思.我也有写过一个简单的内核驱动读写.详情请看内核驱动目录.

所以说虚拟内存是假的.当用的时候才会存储在物理内存

二丶物理内存的管理.

  物理内存是使用4K的方式来管理的.也就是4096个字节.也成为一页.所以以后我们使用API的时候. 大多数都会发现跟页相关.这也是因为管理是页方式管理的原因.

如下图所示

  

进程A 的数值放到物理页中.

而我们进程传统意义上说是由4GB 其实分为高低2G. 高两G是给内核使用的.所以用户只能使用低2G. 而低两G也有高低64k不能使用的. (学过内核想使用自己构造即可)

如下图所示:

用户模式可以使用的内存就是橘黄色的位置.但是没有对应的物理页.当我们申请了内存才会有对应的物理页

如果想看三环程序使用的物理页.可以通过双机调试. 调试我们的程序. 使用Windbg.

1.首先使用命令  !Process 遍历出我们程序Exe的地址.

2.使用   dt EPROCESS  遍历出的地址  得到这个应用程序的EPROCESS结构.

3. 得到EPROCESS + 11c (也就是成员)VadRoot的偏移. 使用!VAD 地址. (EPROCESS + 地址)  可以得出这个EXE使用的内存物理页.

如果不会使用也无所谓. 观看下图:

这个图说明了 我们的线性地址10开始 - 10结束. 因为物理页是4K 存储的.所以10 代表的就是1000  后面大小是1000 所以下一个位置是20开始也就是 2000线性地址.

三丶物理页大小.  

  物理页大小根据你的物理内存.大小来设置的.也就是说你的物理内存多大就可以换算出来.我们可以通过任务管理器查看你的物理页总数.

例如下图:

  

我们换算一下. 1048048 / 4  转换为16进制 则是可以有多少个物理页. 例如我们例子则是 3FF7C 个物理页.

我们也可以使用Windbg dd一下查看. 只需要DD这个变量即可.

如果我们的物理页超过了.那么操作系统还支持使用硬盘来当物理内存.

具体设置

计算机属性 -> 高级系统设置 -> 高级 - > 性能设置 -> 高级 -> 虚拟内存更改.

而这快内存会在windows上保存着. 文件名是 pagefile.sys 一般是C盘的隐藏文件.我们可以通过

EveryThing搜索一下. 

三丶操作系统可识别内存

  我们可用的内存就是 我们算出的物理页的大小 + 虚拟内存的大小.但是操作系统可识别的不是这么大的.

也就是说我们物理内存条加了好多好多.那是一点用没有.

  32位系统下能识别64G内存. winxp只能识别4G内存. 具体知识需要学习Windows内核中的页表 (PTE PDE) 页目录表 等才能清楚. 不多说.只需要了解即可.

原文地址:https://www.cnblogs.com/iBinary/p/9581594.html

时间: 2024-10-12 20:40:47

Win32之内存管理之虚拟内存跟物理内存的相关文章

Windows内存管理

虚拟地址空间 现代CPU执行程序指令访问内存时,它接受的是虚拟地址.它会先使用硬件将虚拟地址转译为物理地址,然后就可以访问物理内存.通过虚拟地址访问内存有以下优势: 程序可以使用一系列相邻的虚拟地址来访问物理内存中不相邻的大内存缓冲区. 程序可以使用一系列虚拟地址来访问大于可用物理内存的内存缓冲区.当物理内存的供应量变小时,内存管理器会将物理内存页(通常大小为 4 KB)保存到磁盘文件.数据或代码页会根据需要在物理内存与磁盘之间移动. 不同进程使用的虚拟地址彼此隔离.一个进程中的代码无法更改正在

windows内存详解(一) 全面介绍Windows内存管理机制及C++内存分配实例

十分感谢MS社区的帖子,讲得很好~ http://social.technet.microsoft.com/Forums/zh-CN/2219/thread/afc1269f-fe08-4dc7-bb94-c395d607e536 (一):进程空间 在编程中,很多Windows或C++的内存函数不知道有什么区别,更别谈有效使用:根本的原因是,没有清楚的理解操作系统的内存管理机制,本文企图通过简单的总结描述,结合实例来阐明这个机制. 本文目的: 对Windows内存管理机制了解清楚,有效的利用C+

全面介绍内存管理机制

全面介绍Windows内存管理机制及C++内存分配实例 十分感谢MS社区的帖子,讲得很好~ http://social.technet.microsoft.com/Forums/zh-CN/2219/thread/afc1269f-fe08-4dc7-bb94-c395d607e536 (一):进程空间 在编程中,很多Windows或C++的内存函数不知道有什么区别,更别谈有效使用:根本的原因是,没有清楚的理解操作系统的内存管理机制,本文企图通过简单的总结描述,结合实例来阐明这个机制. 本文目的

计算机操作系统学习笔记_8_内存管理 --虚拟内存管理

td p { margin-bottom: 0cm; }h2.western { font-family: "Liberation Sans",sans-serif; font-size: 16pt; }h2.cjk { font-family: "微软雅黑"; font-size: 16pt; }h2.ctl { font-family: "AR PL UMing CN"; font-size: 16pt; }h1 { margin-botto

Win32内存管理

 2 地址空间的划分 2.1 用户空间 地址范围:(0 – 0x7FFFFFFF) 2G,运行应用程序的代码.数据等. 2.1.1 NULL区(空指针区) 地址范围:(0 – 0x0000FFFF), 2.1.2 用户区 地址范围:(0x00010000 – 0x7FFEFFFF) 2.1.3 64k禁入区(存在于Win XP,而Win 7,Win 8 不一定存在) 地址范围:(0x7FFEFFFF – 0x7FFFFFFF) 2.2 内核空间 地址范围:(0x80000000 – 0xFF

堆内存 栈内存 虚拟内存 动态内存管理

从编译器角度来看内存分三种情况: 1 系统初始化时都已经确定好.不会再变动的内存区域,一般指的是全局变量.静态变量数组等. 2 栈上内存:一般指的是函数内部的局部变量等,函数调用时分配内存,调用结束后系统自动释放不用自己考虑回收,效率高.有时候栈需要自己设定,设定不当可造成栈溢出. 3 堆上内存:即用动态分配函数分配的内存属于堆上内存,适合那些有MMU(内存管理).开始不确定需要申请多大内存的场合.注意:利用动态分配内存函数,使用完毕要及时释放内存和将指针清0,否则容易产生野指针和内存泄露.因为

(转)从内存管 理、内存泄漏、内存回收探讨C++内存管理

http://www.cr173.com/html/18898_all.html 内存管理是C++最令人切齿痛恨的问题,也是C++最有争议的问题,C++高手从中获得了更好的性能,更大的自由,C++菜鸟的收获则是一遍一遍的检查代码和对 C++的痛恨,但内存管理在C++中无处不在,内存泄漏几乎在每个C++程序中都会发生,因此要想成为C++高手,内存管理一关是必须要过的,除非放弃 C++,转到Java或者.NET,他们的内存管理基本是自动的,当然你也放弃了自由和对内存的支配权,还放弃了C++超绝的性能

C++内存管理(超长,例子很详细,排版很好)

[导语] 内存管理是C++最令人切齿痛恨的问题,也是C++最有争议的问题,C++高手从中获得了更好的性能,更大的自由,C++菜鸟的收获则是一遍一遍的检查代码和对C++的痛恨,但内存管理在C++中无处不在,内存泄漏几乎在每个C++程序中都会发生,因此要想成为C++高手,内存管理一关是必须要过的,除非放弃C++,转到Java或者.NET,他们的内存管理基本是自动的,当然你也放弃了自由和对内存的支配权,还放弃了C++超绝的性能.本期专题将从内存管理.内存泄漏.内存回收这三个方面来探讨C++内存管理问题

C++内存管理(超长)

[导语] 内存管理是C++最令人切齿痛恨的问题,也是C++最有争议的问题,C++高手从中获得了更好的性能,更大的自由,C++菜鸟的收获则是一遍一遍的检查代码和对C++的痛恨,但内存管理在C++中无处不在,内存泄漏几乎在每个C++程序中都会发生,因此要想成为C++高手,内存管理一关是必须要过的,除非放弃C++,转到Java或者.NET,他们的内存管理基本是自动的,当然你也放弃了自由和对内存的支配权,还放弃了C++超绝的性能.本期专题将从内存管理.内存泄漏.内存回收这三个方面来探讨C++内存管理问题