2023年-实验9虚拟存储器.docx
《2023年-实验9虚拟存储器.docx》由会员分享,可在线阅读,更多相关《2023年-实验9虚拟存储器.docx(9页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、实验9、Windows虚拟内存1背景知识在Windows环境下,4GB的虚拟地址空间被划分成两个部分:低端2GB提供给进程使 用,高端2GB提供给系统使用。这意味着用户的应用程序代码,包括DLL以及进程使用的 各种数据等,都装在用户进程地址空间内(低端2GB)。用户过程的虚拟地址空间也被分成三 部分:1)虚拟内存的已调配区(committed):具有备用的物理内存,根据该区域设定的访问权限, 用户可以进行写、读或在其中执行程序等操作。2)虚拟内存的保留区(reserved):没有备用的物理内存,但有一定的访问权限。3)虚拟内存的自由区(free):不限定其用途,有相应的PAGE_NOACCES
2、S权限。与虚拟内存区相关的访问权限告知系统进程可在内存中进行何种类型的操作。例如,用 户不能在只有PAGE,READONLY权限的区域上进行写操作或执行程序;也不能在只有 PAGE_EXECUTE权限的区域里进行读、写操作。而具有PAGE_NOACCESS权限的特殊区 域,则意味着不允许进程对其地址进行任何操作。在进程装入之前,整个虚拟内存的地址空间都被设置为只有PAGE_NOACCESS权限的 自由区域。当系统装入进程代码和数据后,才将内存地址的空间标记为已调配区或保留区, 并将诸如EXECUTE READWRITE和READONLY的权限与这些区域相关联。如表1所示,给出了 MEMORY_
3、BASICNFORMATION的结构,此数据描述了进程虚 拟内存空间中一组虚拟内存页面的当前状态,其中State项表明这些区域是否为自由区、已 调配区或保留区;Protect项则包含了 Windows系统为这些区域添加了何种访问保护;Type 项则表明这些区域是可执行图像、内存映射文件还是简单的私有内存。VirtualQueryEX()API 能让用户在指定的进程中,对虚拟内存地址的大小和属性进行检测。Windows还提供了一整套能使用户精确控制应用程序的虚拟地址空间的虚拟内存APL 一些用于虚拟内存操作及检测的API如表2所示。表 1 MEMORY_BASICNFORMATION 结构的成员
4、成员名称目的PVOID BaseAddress虚拟内存区域开始处的指针PVOID AllocationBase如果这个特定的区域为子分配区的话,则为虚拟内存外面区域的 指针;否则,此值与Base Address相同DWORDAllocationProtect虚拟内存最初分配区域的保护属性。其可能值包括: PAGE_NOACCESS,PAGE_READONLY,PAGE_READWRITE 和 PAGE_EXECUTE_READDWORD RegionSize虚拟内存区域的字节数DWORD State区域的当前分配状态。其可能值为MEM_COMMIT,MEM_FREE 和 MEM_RESERVE
5、DW()RD Protect虚拟内存当前区域的保护属性。可能值与AllocationProtect成员的 相同DWORD Type虚拟内存区域中出现的页面类型。可能值为MEMMAGE,MEM_MAPPED 和 MEM_PRIVATE表2虚拟内存的APIAPI名称描述VirtualQueryEx()通过填充MEMORY_BASIC_INFORMATION结构检测进程内虚拟内 存的区域VirtuaAlloc()保留或调配进程的部分虚拟内存,设置分配和保护标志VirtualFree()释放或收回应用程序使用的部分虚拟地址VirtualProtect()改变虚拟内存区域保护规范VirtualLock(
6、)防止系统将虚拟内存区域通过系统交换到页面文件中VirtualUnlock()释放虚拟内存的锁定区域,必要时,允许系统将其交换到页面文件中提供虚拟内存分配功能的是VinualAlloc()APIo该API支持用户向系统要求新的虚拟内 存或改变已分配内存的当前状态。用户若想通过VirtualAlloc()函数使用虚拟内存,可以采用 两种方式通知系统:1 )简单地将内存内容保存在地址空间内。2)请求系统返回带有物理存储区(RAM的空间或换页文件)的部分地址空间。用户可以用flAllocation Type参数(commit和reserve)来定义这些方式,用户可以通知 Windows按只读、读写、
7、不可读写、执行或特殊方式来处理新的虚拟内存。与VirtualAlloc()函数对应的是VirtualFree。函数,其作用是释放虚拟内存中的已调配页 或保留页。用户可利用dwFreeType参数将已调配页修改成保留页属性。VirtualProtect。是VirtualAlloc()的一个辅助函数,利用它可以改变虚拟内存区的保护规 范。2实验目的1)通过实验了解Windows内存的使用,学习如何在应用程序中管理内存,体会Windows 应用程序内存的简单性和自我防护能力。2)学习检查虚拟内存空间或对其进行操作。3)了解Windows的内存结构和虚拟内存的管理,进而了解进程堆和Windows为使用
8、内 存而提供的一些扩展功能。3实验内容与步骤虚拟内存的检测清单2所示的程序使用VirtualQueryEX。函数来检查虚拟内存空间。步骤1:在“开始”菜单中单击“程序、Microsoft Visual Studio 6. 0”、u MicrosoftVisualC+4-6. 0 ”,进入 VisualC+窗 口。步骤2:运行以下程序清单清单2检测进程的虚拟地址空间#include#include#include#include#pragma comment(lib,nshlwapi.libn)/以可读方式对用户显示保护的辅助方法。保护标记表示允许应用程序对内存进行访问的类型以及操作系统强制访问
9、的类型 inline bool TestSet(DWORD dwTarget, DWORD dwMask)return(dwTarget & dwMask)=dwMask);)#define SHOWMASK(dwTarget,type)if(TestSet(dwTarget,PAGE_#type)std: coutn, #ty pe;void ShowProtection(DWORD dwTarget) (SHOWMASK(dwTarget,READONLY);SHOWMASK(dwTargeUGUARD);SHOWMASK(dwTarget,NOCACHE);SHOWMASK(dwTarg
10、et,READWRITE);SHOWMASK(dwTarget,WRITECOPY);SHOWMASK(dwTarget,EXECUTE);SHOWMASK(dwTarget,EXECUTE_READ);SHOWMASK(dwTarget,EXECUTE_READWRITE);SHOWMASK(dwTarget,EXECUTE_WRITECOPY);SHOWMASK(dwTarget,NOACCESS);)遍历整个虚拟内存并对用户显示其属性的工作程序的方法void WalkVM(HANDLE hProcess) (首先,获得系统信息SYSTEM INFO si;:ZeroMemory(&si,
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 2023 实验 虚拟 存储器
限制150内