参考文献:

http://blog.csdn.net/wubin1124/article/details/3760242

工作集(内存): 可以这么理解, 此值就是该进程所占用的总物理内存. 但是这个值是由两部分组成, 即 '专用工作集' + '共享工作集'.

内存(专用工作集): 这对于一个进程是最重要的, 它代表了一个进程独占用了多少内存.

内存(共享工作集): 这是该进程和别的进程共享的内存量. 通常, 这是加载一个 dll 所占用的内存.

提交大小: 属于 Committed 那一类. 但是不一定在物理内存中, 有些可能位于交换文件中. 如果有一个程序, 原本占 500MB 内存, 但是绝大多数内存都不使用, 则可以通过 `EmptyWorkingSet` 向操作系统发送请求, 将此进程的不常用的内容从物理内存中换出到换页文件中保存, 如下图:


写在最后


0. 工作集, 即在物理内存中的数据的集合.

1. 工作集 = 专用 + 共享

2. 将所有的 "工作集" 相加后的值会大于任务管理器中内存占用的百分比, 因为百分比对共享内存进行排重了.

3. "提交大小" 和 "工作集" 是两个层面的概念, 大部分活跃进程的 "工作集" 会大于 "提交大小", 而大部分非活跃的进程 "工作集" 会小于 "提交大小", 但是两者没有绝对关系.

4. 虚拟内存: 就是换页文件.

分页文件:硬盘上一个或者多个隐藏文件pagefile.sys,Windows用于存储未存入内存的部分程序和数据文件。页面文件和物理内存或随机存取内存(RAM)构成了虚拟内存。Windows会根据需要将数据从页面文件移至内存,或将数据从内存移至页面文件以便为新数据释放内存。也叫“交换文件”。

Windows使用工具集:

Sysinternals Suite

https://technet.microsoft.com/zh-cn/library/bb842062.aspx


分页和非分页内存
Windows规定有些虚拟内存页面是可以交换到磁盘的文件中的,这类内存被称为分页内存,而有些虚拟内存是不能被交换到磁盘的文件中,这些内存被称为非分页内存。当程序的中断请求在DISPATCH_LEVEL之上时,包括DISPATCH_LEVEL,程序只能使用非分页内存。

// WindbgCmdTest.cpp : Defines the entry point for the console application.
// #include "stdafx.h"
#include <iostream>
#include <Windows.h>
using namespace std;
#pragma comment(lib,"Psapi.lib")
#include <Psapi.h> #define MEM_M (1024*1024)
void OutputSystemMem(MEMORYSTATUS New, MEMORYSTATUS Old)
{
//cout<<"减少物理内存="<<(New.dwAvailPhys-Old.dwAvailPhys)/MEM_M<<endl;
//cout<<"减少可用页文件="<<(New.dwAvailPageFile-Old.dwAvailPageFile)/MEM_M<<endl;
//cout<<"减少可用进程空间="<<(New.dwAvailVirtual-Old.dwAvailVirtual)/MEM_M<<endl;
} static PROCESS_MEMORY_COUNTERS stLastMem; void OutputProcessMem()
{
PROCESS_MEMORY_COUNTERS pro;
HANDLE handle = GetCurrentProcess();
GetProcessMemoryInfo(handle, &pro, sizeof(pro));
cout<<"缺页中断次数 "<<"new("<<pro.PageFaultCount/MEM_M<<") "<<"old("<<stLastMem.PageFaultCount/MEM_M<<")"<<endl;
cout<<"使用内存高峰 "<<"new("<<pro.PeakWorkingSetSize/MEM_M<<") "<<"old("<<stLastMem.PeakWorkingSetSize/MEM_M<<")"<<endl;
cout<<"当前使用的内存 "<<"new("<<pro.WorkingSetSize/MEM_M<<") "<<"old("<<stLastMem.WorkingSetSize/MEM_M<<")"<<endl;
cout<<"使用页面缓存池高峰 "<<"new("<<pro.QuotaPeakPagedPoolUsage/MEM_M<<") "<<"old("<<stLastMem.QuotaPeakPagedPoolUsage/MEM_M<<")"<<endl;
cout<<"使用页面缓存池 "<<"new("<<pro.QuotaPagedPoolUsage/MEM_M<<") "<<"old("<<stLastMem.QuotaPagedPoolUsage/MEM_M<<")"<<endl;
cout<<"使用非分页缓存池高峰 "<<"new("<<pro.QuotaPeakNonPagedPoolUsage/MEM_M<<") "<<"old("<<stLastMem.QuotaPeakNonPagedPoolUsage/MEM_M<<")"<<endl;
cout<<"使用非分页缓存池 "<<"new("<<pro.QuotaNonPagedPoolUsage/MEM_M<<") "<<"old("<<stLastMem.QuotaNonPagedPoolUsage/MEM_M<<")"<<endl;
cout<<"使用分页文件(提交的内存文件大小) "<<"new("<<pro.PagefileUsage/MEM_M<<") "<<"old("<<stLastMem.PagefileUsage/MEM_M<<")"<<endl;
cout<<"使用分页文件高峰 "<<"new("<<pro.PeakPagefileUsage/MEM_M<<") "<<"old("<<stLastMem.PeakPagefileUsage/MEM_M<<")"<<endl;
cout<<endl;
memcpy(&stLastMem,&pro,sizeof(pro));
}
#define VIRTUAL_ALLOC_TEST_SIZE 10*MEM_M
int _tmain(int argc, _TCHAR* argv[])
{
memset(&stLastMem,0,sizeof(stLastMem));
OutputProcessMem(); MEMORYSTATUS memStatusVirtual;
GlobalMemoryStatus(&memStatusVirtual); LPVOID pV=VirtualAlloc(NULL,VIRTUAL_ALLOC_TEST_SIZE,MEM_RESERVE|MEM_TOP_DOWN,PAGE_READWRITE);
if(pV==NULL)
{
cout<<"没有那么多虚拟空间!"<<endl;
}
MEMORYSTATUS memStatusVirtual1;
GlobalMemoryStatus(&memStatusVirtual1);
cout<<"VirtualAlloc(NULL,1000*1024*1024,MEM_RESERVE|MEM_TOP_DOWN,PAGE_READWRITE);"<<endl;
OutputSystemMem(memStatusVirtual1,memStatusVirtual);
OutputProcessMem(); cout<<"\n";
pV=VirtualAlloc(pV,VIRTUAL_ALLOC_TEST_SIZE,MEM_COMMIT,PAGE_READWRITE);
if (pV == NULL)
{
DWORD eLastError = GetLastError();
cout <<"eLastError: %d" << eLastError;
}
MEMORYSTATUS memStatusVirtual2;
GlobalMemoryStatus(&memStatusVirtual2);
cout<<"VirtualAlloc(pV,10*1024*1024,MEM_COMMIT|MEM_RESERVE,PAGE_READWRITE);"<<endl;
OutputSystemMem(memStatusVirtual2,memStatusVirtual1);
OutputProcessMem(); char * pC = (char *)pV;
cout<<"\n";
cout<<"pC[VIRTUAL_ALLOC_TEST_SIZE-1] = 0;;"<<endl;
pC[VIRTUAL_ALLOC_TEST_SIZE-1] = 0;
OutputProcessMem(); cout<<"\n";
char * p = new char[10*MEM_M];
MEMORYSTATUS memStatusVirtual8;
GlobalMemoryStatus(&memStatusVirtual8);
cout<<"char * p = new char[10*MEM_M];"<<endl;
OutputSystemMem(memStatusVirtual8,memStatusVirtual2); OutputProcessMem(); cout<<"\n";
VirtualFree(pV,VIRTUAL_ALLOC_TEST_SIZE,MEM_DECOMMIT);
MEMORYSTATUS memStatusVirtual3;
GlobalMemoryStatus(&memStatusVirtual3);
cout<<" VirtualFree(pV,10*1024*1024,MEM_DECOMMIT);"<<endl;
OutputSystemMem(memStatusVirtual3,memStatusVirtual2);
OutputProcessMem(); cout<<"\n";
VirtualFree(pV,VIRTUAL_ALLOC_TEST_SIZE,MEM_RELEASE);
MEMORYSTATUS memStatusVirtual4;
GlobalMemoryStatus(&memStatusVirtual4);
cout<<"VirtualFree(pV,10*1024*1024,MEM_RELEASE);"<<endl;
OutputSystemMem(memStatusVirtual4,memStatusVirtual3);
OutputProcessMem(); cout<<"\n";
VirtualUnlock(pV,VIRTUAL_ALLOC_TEST_SIZE);
MEMORYSTATUS memStatusVirtual5;
GlobalMemoryStatus(&memStatusVirtual5);
cout<<"VirtualUnlock(pV,10*1024*1024);"<<endl;
OutputSystemMem(memStatusVirtual5,memStatusVirtual4);
OutputProcessMem(); cout<<"delete[] p;"<<endl;
delete[] p;
OutputProcessMem(); getchar();
return 0;
}


Windows 内存管理的更多相关文章

  1. Windows内存管理[转]

    本文主要内容:1.基本概念:物理内存.虚拟内存:物理地址.虚拟地址.逻辑地址:页目录,页表2.Windows内存管理3.CPU段式内存管理4.CPU页式内存管理 一.基本概念1. 两个内存概念物理内存 ...

  2. windows内存管理方式以及优缺点

    Windows内存管理方式:页式管理,段式管理,段页式管理 页式管理 将各进程的虚拟空间(逻辑地址)划分为若干个长度相等的页,业内管理把内存空间(物理内存)按照页的大小划分为片或者页面,从而实现了离散 ...

  3. windows 内存管理的几种方式及其优缺点

    windows 内存管理方式主要分为:页式管理,段式管理,段页式管理. 页式管理的基本原理是将各进程的虚拟空间划分为若干个长度相等的页:页式管理把内存空间按照页的大小划分成片或者页面,然后把页式虚拟地 ...

  4. 全面介绍Windows内存管理机制及C++内存分配实例(四):内存映射文件

    本文背景: 在编程中,很多Windows或C++的内存函数不知道有什么区别,更别谈有效使用:根本的原因是,没有清楚的理解操作系统的内存管理机制,本文企图通过简单的总结描述,结合实例来阐明这个机制. 本 ...

  5. Windows内存管理的方式

    一.内存的概念 1. 物理内存:即插在主板上的内存条.他是固定的,内存条的容量多大,物理内存就有多大(集成显卡系统除外). 但是如果程序运行很多或者程序本身很大的话,就会导致大量的物理内存占用,甚至导 ...

  6. 20140919 进程间通信 系统栈 用户栈 多级反馈队列 windows 内存管理

    1.进程间通信 共享内存(剪切板) 匿名管道只能实现父子进程间的通信(以文件系统为基础): 匿名管道是什么,有什么用,怎么用 1.创建父进程,也就是在解决方案中建立一个parent的工程 2.在par ...

  7. 全面介绍Windows内存管理机制及C++内存分配实例

    转自:http://blog.csdn.net/yeming81/article/details/2046193 本文基本上是windows via c/c++上的内容,笔记做得不错.. 本文背景: ...

  8. Windows内存管理

    本博文很大程度上参考了,潘爱民先生的<Windows内核原理与实现>一书,在此对他表示感谢. 记得是在学C语言指针的时候,首次比较实际的使用内存寻址.也是在那个时候知道不能使用未初始化的指 ...

  9. Windows内存管理简介:

    1:连续的内存空间分配: (1)单一连续分配:只能单作业,单任务运行: 分为系统和用户区:用户区是指除了系统需外左右的内存,由于单用户,单任务,要不都被占用,要不全空   (2):固定空间分配:固定分 ...

  10. Windows程序设计学习笔记(一)Windows内存管理初步

    学习Windows程序设计也有一些时间了,为了记录自己的学习成果,以便以后查看,我希望自己能够坚持写下一系列的学习心得,对自己学习的内容进行总结,同时与大家交流.因为刚学习所以可能有的地方写不不正确, ...

随机推荐

  1. [Big Data - Suro] Netflix开源数据流管理器Suro

    Netflix近日开源了一个叫做Suro的工具,公司可以利用它来做数据源主机到目标主机的实时定向.它不只在Netflix的数据管道上扮演重要角色,大规模下的应用场景同样令人印象深刻. Netflix各 ...

  2. [Android]Android数据的四种存储方式

    存储方式 Android提供以下四种存储方式: SharePreference SQLite File ContentProvider Android系统中数据基本都是私有的,一般存放在“data/d ...

  3. Maven包下载不下来的情况

    从svn上遇到过项目下载下来,缺丢失了一些包,怎么都下载不了,只能从同事的电脑上给拷贝下来? 千万别这样,别问为何,说多了都是泪,然后发现. 如果是eclipse的话: 勾选这两个选项,就能下载下来了 ...

  4. 【九天教您南方cass 9.1】 12 道路断面土方计算

    同学们大家好,欢迎收看由老王测量上班记出品的cass9.1视频课程 我是本节课主讲老师九天. 我们讲课的教程附件也是共享的,请注意索取 在测量空间中. [点击索取cass教程]5元立得 (给客服说暗号 ...

  5. 【iCore4 双核心板_ARM】例程十五:USB_CDC实验——高速数据传输

    实验方法: 1.安装USB CDC驱动,驱动安装方法参考例程包中安装方法文档. 2.将跳线冒跳至USB_OTG,通过Micro USB 线将iCore4 USB-OTG接口与电脑相连. 3.打开上位机 ...

  6. 【网络编程】——ne-snmp开发实例1

    net-snmp扩展有多种方式,在此只介绍两种——动态库扩展,静态库扩展. 在做net-snmp开发之前,首先确定net-snmp相关的软件是否安装. rpm -qa | grep snmp net- ...

  7. 嵌入式开发之hi3519---PCIE DMA

    http://blog.csdn.net/abcamus/article/details/76167747 大话pcie dma http://blog.csdn.net/qingfengtsing/ ...

  8. C# 窗口和程序的退出

    Application.Exit(); // 通知所有消息泵必须终止,并且在处理了消息以后关闭所有应用程序窗口. // 由 .NET Compact Framework 支持. Form.Close( ...

  9. swoole Tcp

    TCP服务对象 <?php //创建Server对象,监听 127.0.0.1:9501端口 $serv = ); //监听连接进入事件 $serv->on('connect', func ...

  10. mysql的text字段长度?mysql数据库中text字段长度不够的问题

    类型是可变长度的字符串,最多65535个字符:     可以把字段类型改成MEDIUMTEXT(最多存放16777215个字符)或者LONGTEXT(最多存放4294967295个字符). MySQL ...