【操作系统】存储器管理实验

实验目的

  1. 理解WINDOWS中堆、栈的内存布局
  2. 通过WNDOWS系统提供的系统调用HeapCreate(), HeapAlloc(), HeapFree()等函数的应用,理解虚拟内存管理技术中的内存分配原理。使用工具软件vmmap查看某个进程的虚拟地址空间,并理解虚地址空间中的相关术语。
  3. 通过WINDOWS提供的系统调用GetProcessMemoryInfo()理解操作系统原理书中所讲的相关内容。

实验内容

本实验要求用C语言书写一个用到以上系统调用的程序,要求对GetProcessMemoryInfo函数的返回内容理解并解释。

实验准备

相关理论知识

  1. 现代操作系统管理内存的基本原理,理解堆、栈等相关的内存术语。
  2. 了解工作集,缺页中断、页面等基本术语。
  3. 了解WINDOWS中管理内存的基本思想。

相关系统调用的解释

GetProcessMemoryInfo

BOOL WINAPI GetProcessMemoryInfo(_In_HANDLE Process,
_Out_PPROCESS_MEMORY_COUNTERS ppsmemCounters,
_In_DWORD cb);

该函数取一个进程的句柄为参数,返回该进程的内存使用信息。该函数的调用中,最重要的内容是对数据结构PROCESS_MEMORY_COUNTERS的解释。参见MSDN中,对该调用的解释和例子。

HeapAlloc

LPVOID WINAPI HeapAlloc(_In_HANDLE hHeap,_In_DWORD dwFlags,  _In_SIZE_T dwBytes);

该函数取一个堆的句柄为参数,返回在dwBytes参数中设定的参数的内存大小。创建堆或获取堆的方法见MSDN。

实验过程

源代码

#include <stdlib.h>
#include <Windows.h>
#include <stdio.h>
#include <psapi.h>
void HeapInfo(HANDLE hHeap){
    PROCESS_MEMORY_COUNTERS pmc;
    if ( GetProcessMemoryInfo( hHeap, &pmc, sizeof(pmc)) )
    {
    printf( "\t页表错误数: 0x%08X\n", pmc.PageFaultCount );
    printf( "\t峰值工作集大小: 0x%08X\n",
    pmc.PeakWorkingSetSize );
    printf( "\t工作集大小: 0x%08X\n", pmc.WorkingSetSize );
    printf( "\t配额峰值分页池使用: 0x%08X\n",
    pmc.QuotaPeakPagedPoolUsage );
    printf( "\t配额分页池使用: 0x%08X\n",
    pmc.QuotaPagedPoolUsage );
    printf( "\t配额峰值未分页池使用: 0x%08X\n",
    pmc.QuotaPeakNonPagedPoolUsage );
    printf( "\t配额未分页池使用: 0x%08X\n",
    pmc.QuotaNonPagedPoolUsage );
    printf( "\t页面文件使用: 0x%08X\n", pmc.PagefileUsage );
    printf( "\t峰值页面文件使用: 0x%08X\n",
                pmc.PeakPagefileUsage );
    }
}
int main()
{

    //创建堆
    HANDLE hHeap = HeapCreate(
                        HEAP_GENERATE_EXCEPTIONS,
                        1024 * 1024, 0 );
    printf( "创建堆: %p\n",hHeap );
    CHAR * pszBuf = (CHAR *)HeapAlloc( hHeap,HEAP_ZERO_MEMORY, 100 );
    
    HeapInfo(hHeap);

    //内存分配
    printf( "堆分配: %p\n",pszBuf );

    strcpy( pszBuf, "hello Heap");
    printf( "%s\n", pszBuf );

    //内存释放
    HeapFree( hHeap, 0, pszBuf );

    //释放堆
    HeapDestroy( hHeap );

    HeapInfo(hHeap);

    CloseHandle( hHeap );
    return 0;
}
  • 0
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
实验目的】 1. 通过编写和调试存储管理的模拟程序以加深对存储管理方案的理解; 2. 熟悉虚存管理的各种页面淘汰算法; 3. 通过编写和调试地址转换过程的模拟程序以加强对地址转换过程的了解。 【实验准备】 1.虚拟存储器的管理方式  段式管理  页式管理  段页式管理 2.页面置换算法  先进先出置换算法  最近最久未使用置换算法  Clock置换算法  其他置换算法 【实验内容】 1. 实验题目 设计一个请求页式存储管理方案。并编写模拟程序实现之。产生一个需要访问的指令地址流。它是一系列需要访问的指令的地址。为不失一般性,你可以适当地(用人工指定地方法或用随机数产生器)生成这个序列,使得 50%的指令是顺序执行的。25%的指令均匀地散布在前地址部分,25%的地址是均匀地散布在后地址部分。为简单起见。页面淘汰算法采用 FIFO页面淘汰算法,并且在淘汰一页时,只将该页在页表中抹去。而不再判断它是否被改写过,也不将它写回到辅存。 2. 具体做法 产生一个需要访问的指令地址流;指令合适的页面尺寸(例如以 1K或2K为1页);指定内存页表的最大长度,并对页表进行初始化;每访问一个地址时,首先要计算该地址所在的页的页号,然后查页表,判断该页是否在主存——如果该页已在主存,则打印页表情况;如果该页不在主存且页表未满,则调入一页并打印页表情况;如果该页不足主存且页表已满,则按 FIFO页面淘汰算法淘汰一页后调入所需的页,打印页表情况;逐个地址访问,直到所有地址访问完毕。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

cout0

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值