来源:

http://www.cnblogs.com/georgepei/archive/2012/03/07/2383445.html

http://www.cnblogs.com/georgepei/archive/2012/03/07/2383548.html

任务管理器中跟内存相关有两个重要的指标Private(提交大小)和working set(工作设置)。如下图所示:

这两个指标在process explorer中叫做Private Bytes和Working Set。

而在VMMap中,他们则分别被叫做Private和Total Working Set。我这里也用Private和working set来称呼他们。

他们经常被用来标识一个进程到底占用了多少内存,你知道他们分别代表什么吗?

Private指的是当你修改他时仅仅当前进程会受到影响。(copy-on-wirte属性的页面还没被修改时也属于此类)。这类一般包括Heap,stack和image的copy-on-write的部分。Private是虚拟内存的概念,其对应的内存可能被物理内存backup,也可能被paging file backup。比如用new来创建一个100M的内存时,private就增加100M,但是这块内存在被访问之前,实际上是paging file backup的,物理内存并没有真正占用。(win7下测试所得)

Working set是指物理内存。但是这个物理内存既包括了属于当前进程的私有物理内存(Private Working set)。也包括了可以共享的Working set(Sharable Working Set)。Private Working Set 就是前面的Private的一部分,Private的另外一部分由paging file backup。

在VMMap中,还有一个概念是Committed,它也是虚拟内存的概念,其实可以分为Private的虚拟内存和可以共享的虚拟内存。而可以共享的虚拟内存的由物理内存backup的部分就是sharable working set。

所以:

从私有和可共享的角度来看:
Committed = Private virtual memory + sharable virtual memory

从memory由什么back up来看:

Committed = memory backed by paging file + working set

Private Virtual Memory = Private Working set + private memory backed by paging file

Working set = private working set + sharable working set

-------------

上面介绍了任务管理器中关于内存的两个重要概念:private和working set。但是内存远不止那么简单,下面我根据VMMap来详细介绍一下内存的分类。

内存是一个很复杂的系统,其中的paging file,sharable memory,reserve和commit等概念使得要算清楚一个进程到底使用了多少内存几乎成了不可能的事情了。

还好我们有VMMap这个工具,它用两个纬度将内存进行了详细的划分。

一个是纵向的纬度,也就是内存是从哪里来的。分为

  1. Image(可执行文件),
  2. Mapped file(由CreateFileMapping以文件作为back up)。
  3. Sharable(由CreateFileMapping以内存作为 back up)
  4. Private Data(由Virtual Alloc分配)
  5. Heap(由new,GlobalAlloc和HeapAlloc等分配)
  6. Stack(栈占用的控件)
  7. Page table(内核里面维护当前虚拟地址控件所需要的内存)
  8. Managed Heap(由.NET garbage collector分配和管理)

还有一个横向的维护,分别被称为:

  1. Size: 总体大小,包括了commit和没有reservce的内存。如果这项和Committed不 一致,那么就是说有reserve的内存。
  2. Committed: committed的大小,包括Private内存和可共享的内存。
  3. Private:属于当前进程的虚拟内存,指的是当你修改他时仅仅当前进程会受到影响。(copy-on-wirte属性的页面还没被修改时也属于此类)

以上实际上是虚拟内存(virtual memory)的概念,其中的内容可能被物理内存(physical memory)back up,也可能被Paging file back up。

而以下的几个指标指的是物理内存:

  1. Total WS: 所有的working set,包括private working set和sharable working set。
  2. Private WS: private working set。仅属于当前进程的working set。
  3. Sharable WS。可共享的working set。
  4. Shared WS。已经共享的working set,这个值应该是sharable working set的一部分或者全部。

为了更具体的了解这几个指标,下面我们根据一些API的具体行为所产生的结果来观察一下他们的含义。

New,GlobalAlloc and HeapAlloc:

受影响的是VMMap中的Heap行。

分配时占用的是Committed和Private列,working set不受影响。

当访问时Total working set和Private Working Set跟着上升。

VirtualAlloc:

受影响的是VMMap中的Private Data行。

分配Reserve的data时,上升的是第一列Size,第二列Committed不变。

Commit时,上升的是Committed和Private列。Total Working Set列不变。

当访问Commit的内存时,上升的是Total Working set 和Private Working set列。

DeCommit时,只有第一列size保持不变,Committed,Private和Working set列都下降。

Release时,第一列Size也下降。

Memory Based CreateFileMapping

这个file mapping不管有没有命名,下面的行为都一样。

受影响的是VMMap中的Sharable行。

调用CreateFileMapping时,不影响任何列,增加的只是系统的Total Commit Charge。

调用MapViewOfFile时,上升的是Size和Committed列。

当访问这些map的数据时,上升的是Total Working Set和Sharable Working Set。

调用UnmapViewOfFile时,Size,Committee和Working set列都下降。

调用CloseHandle来关闭CreateFileMapping创建的handle时,不影响任何列, 但是减少了系统的Total Commit Charge。

共享状态下的Memory based CreateFileMapping

需要注意的是这个file mapping命名了,并且是在同一个进程中打开两次,以达到共享的目的。

受影响的是VMMap中的Sharable列。

调用第一个调用CreateFileMapping时,不影响任何列,增加的只是系统的Total Commit Charge。

调用MapViewOfFile时,上升的是Size和Committed列。

当访问这些map的数据时,上升的是Total Working Set和Sharable Working Set。

以上行为跟前面一个Scenario完全一样,下面要开始创建再次打开刚才创建的File mapping.

当用同样的名字再次调用CreateFileMapping打开前面创建的file mapping时,系统的Total Commit Charge不受影响,也不影响VMMap中的任何列。

调用MapViewOfFile时,上升的是Size和Committed列。也就是说,上升第二次了。

当访问这些map的数据时,上升的是Total Working Set和Sharable Working Set。也是上升第二次。

调用UnmapViewOfFile来ummap掉第二次打开的view,Size,,commmited和working set都下降一半。

调用UnmapViewOfFile来ummap掉第一次打开的view,Size,,commmited和working set都下降到初始状态。

调用CloseHandle来关闭第二次打开的Handle,Total Commit charge不受影响。

调用CloseHandle来关闭第一次打开的Handle,Total Commit charge下降。

File Based CreateFileMapping

受影响的是Mapped File行。

调用CreateFileMapping时,没有影响到VMMap中的任何列,并且跟Memory Based File mapping不一样的是,Total Commit Charge也不受 影响,因为他是以File 作为back up的

调用MapViewOfFile时,上升的是Size和Committed列。跟Memory Based File mapping一样的表现。

当访问这些map的数据时,上升的是Total Working Set和Sharable Working Set。跟Memory Based File mapping一样的表现。

调用UnmapViewOfFile时,Size,Committee和Working set列都下降。跟Memory Based File mapping一样的表现。

调用CloseHandle来关闭CreateFileMapping创建的handle时,不影响任何列, 也不影响Total Commit Charge。

总结:file based和memory based不同点在于:

  1. File based影响是Mapped file行,memory based影响的是Sharable行。
  2. File based 不影响total commit charge, memory based 影响。

在MSDN中搜索CreateFileMapping:
简单来说就是一个内存映射,可以以文件作为back up也可以以内存作为back up。映射出来的内存可以在多个进程间共享,并且这是在多个进程间共享大量数据的主要方式。

VMMap(查看内存工具)的更多相关文章

  1. linux日常管理-free查看内存工具

    查看内存 命令 free  默认是k为单位 也可以指定 m为单位 或者G为单位,这个不精准 total 总容量 used  使用了多少 free  剩余多少 看第二行.第一行是物理内存,加上虚拟内存b ...

  2. 配置JVM内存 查看内存工具

    一.配置JVM内存 1.配置JVM内存的參数有四个: -XmxJavaHeap最大值.默认值为物理内存的1/4.最佳设值应该视物理内存大小及计算机内其它内存开销而定. -XmsJavaHeap初始值, ...

  3. 【Android】开发优化之——调优工具:dump hprof file 查看内存情况,找到内存泄露

    虽说知道一般性的开发android应用须要注意的问题,但是也有水平參差不齐的情况.特别是维护代码,假设内存占用大,内存溢出严重,又怎么解决呢?  --  通过DDMS把heap抓出来分析 1.打开DD ...

  4. SysInternals提供了一个工具RamMap,可以查看内存的具体使用情况

    SysInternals提供了一个工具RamMap,可以查看内存的具体使用情况.如果发现是Paged Pool和Nonpaged Pool占用过大,可以用另一个工具poolmon来查看占用内存的驱动T ...

  5. Linux进程管理——查看内存的工具

    Linux进程管理——查看内存的工具 一查看内存的工具vmstat vmstat命令:虚拟内存信息vmstat [options] [delay [count]]vmstat 2 5 [root@ce ...

  6. 萌新笔记——linux下查看内存的使用情况

    windows上有各种软件可以进行"一键加速"之类的操作,释放掉一些内存(虽然我暂时不知道是怎么办到的,有待后续学习).而任务管理器也可以很方便地查看各进程使用的内存情况,如下图: ...

  7. Android中如何查看内存

    文章参照自:http://stackoverflow.com/questions/2298208/how-to-discover-memory-usage-of-my-application-in-a ...

  8. free命令查看内存使用情况(转载)

    linux free命令查看内存使用情况 时间:2016-01-05 06:47:22来源:网络 导读:linux free命令查看内存使用情况,free命令输出结果的各选项的含义,以及free结果中 ...

  9. ubuntu查看内存占用和查看cpu使用情况的简单方法(ubuntu内存管理)

    单独查看内存使用情况的命令:free -m查看内存及cpu使用情况的命令:top也可以安装htop工具,这样更直观,安装命令如下:sudo apt-get install htop安装完后,直接输入命 ...

随机推荐

  1. 纯Python综合图像处理小工具(1)分通道直方图

    平时工作经常需要做些图像分析,需要给图像分通道,计算各个通道的直方图分布特点,这个事儿photoshop也能做,但是用起来不方便,且需要电脑上安装有PS软件,如果用OpenCV, 更是需要在visua ...

  2. POJ 1654 Area

    题意:从原点出发,沿着8个方向走,每次走1个点格或者根号2个点格的距离,最终回到原点,求围住的多边形面积. 分析:直接记录所经过的点,然后计算多边形面积.注意,不用先保存所有的点,然后计算面积,边走变 ...

  3. 线程内唯一对象HttpContext

    在asp.net中,HttpContext是主线程内唯一对象.在web应用中开启多线程,在另外一个线程中是无法访问HttpContext. 如果需要在另外一个线程中使用HttpContext.Curr ...

  4. Android 短信模块分析(四) MMS之短信的发送与接收

     MMS之短信的发送与接收分析: 一.信息发送: com.android.mms.data.WorkingMessage.java 类 send()函数: public void send() { . ...

  5. 第一章 引言--《设计模式-可复用面向对象软件的基础》Erich Gamma

    第一章 引言 本章主要是让我们大致明白设计模式是干嘛用的,模式分类,设计模式如何解决设计问题以及几种常见的面向对象设计中软件的复用方法. 1.什么是设计模式? 个人理解概括,设计模式是对一类问题的抽象 ...

  6. 横瓜先生关于如何利用MYSQL数据库设计CMS系统处理100亿级TB规模的数据量

    遥执乾坤(44758121)  18:21:23 mysql据说只能使用一个索引,我这里几乎所有字段都有索引. 但每个字段就算用索引,也需要扫描至少100w以上记录. 横瓜(601069289)  1 ...

  7. Qt Creator+MinGW+boost特殊函数的使用示例

    Qt Creator+MinGW+boost特殊函数的使用示例: 先编译和安装boost: bootstrap.bat gcc .\b2 --toolset=gcc --prefix=E:\boost ...

  8. Laravel5.3 流程粗粒度分析之bootstrap

    从laravel入口文件index里面外面不难定位到Illuminate\Foundation\Http\Kernel的handle方法,同样也不难发现handle方法的核心是 $response = ...

  9. C++ unordered_map 在key为string类型和char*类型时测试时间性能差异

    测试系统liunx centos6.5 代码如下 #include <string.h> #include <sstream> #include <list> #i ...

  10. CreateMutex 创建一个有名字的互斥量的时候hMutex=CreateMutex(NULL,TRUE,"tickets")报错

    编译器报错: 不能将参数 3 从“const char [8]”转换为“LPCWSTR”,怎么改成LPCWSTR类型 更改方法: hMutex=CreateMutex(NULL,TRUE,L" ...