转:http://blog.csdn.net/woddle/article/details/45337767

下面我根据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和没有reserve的内存。如果这项和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 影响。

转:VMMAP内存查看工具的更多相关文章

  1. iOS应用程序内存查看工具

    我要找的是一个可以检查应用程序中哪一个数组存贮的什么内容的工具. 网上搜到的工具名称是Allocations Instrument,后来一试发现不是我想要的.这还是一个后期调试阶段的内存检查工具. h ...

  2. linux内存查看工具

    这里帮你总结了一下Linux下查看内存使用情况的多种方法~ 在做 Linux 系统优化的时候,物理内存是其中最重要的一方面.自然的,Linux 也提供了非常多的方法来监控宝贵的内存资源的使用情况.下面 ...

  3. Android内存分析工具

    在Android系统开发过程中,经常会要去分析进程的内存的使用情况,简单介绍下Android内存分析的相关工具. 文章参考: 1.dumpsys 2.memory-analysis-command 1 ...

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

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

  5. Java内存泄露分析和解决方案及Windows自带查看工具

    Java内存泄漏是每个Java程序员都会遇到的问题,程序在本地运行一切正常,可是布署到远端就会出现内存无限制的增长,最后系统瘫痪,那么如何最快最好的检测程序的稳定性,防止系统崩盘,作者用自已的亲身经历 ...

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

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

  7. Windows系统内存分析工具的介绍

      Windows系统内存分析工具的介绍(进程管理器,资源管理器,性能监视器, VMMap, RamMap,PoolMon) 微软官方提供多种工具来分析Windows 的内存使用情况,除了系统自带的任 ...

  8. javascript js 内存泄露工具使用

    javascript内存泄露工具使用 原文:http://lanhy2000.blog.163.com/blog/static/43678608201121472644851/ 2011-03-14 ...

  9. JS内存泄漏 和Chrome 内存分析工具简介(摘)

    原文地址:http://web.jobbole.com/88463/ JavaScript 中 4 种常见的内存泄露陷阱   原文:Sebastián Peyrott 译文:伯乐在线专栏作者 - AR ...

随机推荐

  1. Tensorboard教程:高维向量可视化

    Tensorflow高维向量可视化 觉得有用的话,欢迎一起讨论相互学习~Follow Me 参考文献 强烈推荐Tensorflow实战Google深度学习框架 实验平台: Tensorflow1.4. ...

  2. OpenCV---图像直方图

    一:直方图的直接使用 from matplotlib import pyplot as plt def plot_demo(image): print(image.ravel()) plt.hist( ...

  3. UVA 12063 Zeros and Ones

    https://vjudge.net/problem/UVA-12063 题意: 统计n为二进制数中,0和1相等且值为m的倍数的数有多少个 dp[i][j][k] 前i位二进制 有j个1 值模m等于k ...

  4. python列表排序方法reverse、sort、sorted

    python语言中的列表排序方法有三个:reverse反转/倒序排序.sort正序排序.sorted可以获取排序后的列表.在更高级列表排序中,后两中方法还可以加入条件参数进行排序. reverse() ...

  5. css table-border

    1.table上设边框,td上设边框: <style> table{border-right:1px solid #F00;border-bottom:1px solid #F00} ta ...

  6. Amcharts 柱状图和线形图

    最近需要学习 Amcharts ,他的图表功能确实很强大.但是网上搜索到的教程很少,开始学起的确有点不方便.于是我决定把我学习的觉得好的途径,放到博客上. 下面的代码可以直接复制,但是文件要从官网上下 ...

  7. VideoJS 与 Framework7 中 fastclick 冲突问题

    Framework7 由于自动启用  fastclick,会导致在 移动端下使用 video.js,控制条上的 播放和音量按钮 点击的时候会触发两次. 解决办法: 1. 全局禁用 fastclick, ...

  8. 阿里分布式开源框架DUBBO 入门+ 进阶+ 项目实战视频教程

    史诗级Java/JavaWeb学习资源免费分享 欢迎关注我的微信公众号:"Java面试通关手册"(坚持原创,分享各种Java学习资源,面试题,优质文章,以及企业级Java实战项目回 ...

  9. mysq配置

    mysql运维 1.mysql配置文件:/etc/my.cnf mysql日记文件 :安装时候配置的,可以通过ps aux|grep mysqld 查询 ps aux|grep mysqld mysq ...

  10. ssh使两台机器建立连接

    ssh利用口令建立连接过程: 客户端--> 发送连接请求 --> 远程主机 --> 返回远程主机的公钥 --> 公钥加密客户端私钥+客户端公钥返回远程主机 --> 远程主 ...