文档章节

什么是专用字节,虚拟字节,工作集?

 技术盛宴
发布于 01/24 19:05
字数 1973
阅读 68
收藏 0

我试图使用perfmon Windows实用程序来调试进程中的内存泄漏。

这就是perfmon解释这些术语的方式:

Working Set是此过程的工作集的当前大小(以字节为单位)。 工作集是过程中线程最近触及的一组内存页面。 如果计算机中的可用内存超过阈值,则即使不使用页面,页面也会保留在进程的工作集中。 当可用内存低于阈值时,将从工作集中剪裁页面。 如果需要它们,它们将在离开主存储器之前被软故障返回工作集。

Virtual Bytes是进程正在使用的虚拟地址空间的当前大小(以字节为单位)。 使用虚拟地址空间不一定意味着相应地使用磁盘或主存储器页面。 虚拟空间是有限的,并且该过程可以限制其加载库的能力。

Private Bytes是此进程分配的内存的当前大小(以字节为单位),无法与其他进程共享。

这些是我的问题:

是否应该测量私有字节,以确定进程是否有任何泄漏,因为它不涉及任何共享库,如果发生任何泄漏,将来自进程本身?

该进程消耗的总内存是多少? 它是虚拟字节还是虚拟字节和工作集的总和?

私有字节,工作集和虚拟字节之间是否有任何关系?

还有其他工具可以更好地了解内存使用情况吗?


#1楼

对这个问题的简短回答是, 这些值都不是可执行程序实际使用的内存量的可靠指标,并且它们都不适合调试内存泄漏。

Private Bytes指的是进程可执行文件要求的内存量 - 不一定是它实际使用的量。 它们是“私有的”,因为它们(通常)排除了内存映射文件(即共享DLL)。 但是 - 这是捕获 - 它们不一定排除那些文件分配的内存。 没有办法判断私有字节的更改是由于可执行文件本身还是由于链接库。 专用字节也不仅仅是物理内存; 它们可以被分页到磁盘或备用页面列表(即不再使用,但也没有被分页)。

工作集是指进程使用的总物理内存(RAM)。 但是,与专用字节不同,这还包括内存映射文件和各种其他资源,因此它比专用字节的测量精度更低。 这与在任务管理器的“内存使用”中报告的值相同,并且近年来一直是无穷无尽的混淆源。 工作集中的内存是“物理的”,因为它可以在没有页面错误的情况下进行处理; 然而,在待机页面列表仍然物理内存中但没有报告的工作组,这就是为什么你会看到当最小化应用程序中的“内存使用”突然下降。

虚拟字节是整个进程占用的总虚拟地址空间 。 这就像工作集一样,它包含内存映射文件(共享DLL),但它还包括备用列表中的数据和已经被分页的数据,并且位于磁盘上的页面文件中。 在高负载下系统上的每个进程使用的总虚拟字节将比机器实际拥有的内存大得多。

所以关系是:

  • Private Bytes是您的应用实际分配的内容,但包含页面文件使用情况;
  • Working Set是非分页私有字节加内存映射文件;
  • 虚拟字节是工作集加分页的专用字节和备用列表。

这里还有另一个问题; 就像共享库可以在应用程序模块内部分配内存,导致你的应用程序的专用字节报告的潜在误报, 您的应用程序也可能最终会共享模块内部分配内存,导致假阴性 。 这意味着您的应用程序实际上可能存在内存泄漏,而这种内存泄漏根本不会出现在Private Bytes中。 不太可能,但可能。

Private Bytes是您的可执行文件使用的内存量的合理近似值 ,可用于帮助缩小内存泄漏的潜在候选列表; 如果你看到这个数字不断增长并且不断增长,你会想要检查这个过程是否有泄漏。 但是,这不能证明存在或没有泄漏。

在Windows中检测/纠正内存泄漏的最有效工具之一实际上是Visual Studio (链接转到使用VS进行内存泄漏的页面,而不是产品页面)。 Rational Purify是另一种可能性。 Microsoft还有关于此主题的更一般的最佳实践文档此前一个问题中列出了更多工具。

我希望这清除了一些事情! 追踪内存泄漏是调试中最困难的事情之一。 祝好运。


#2楼

您不应该尝试使用perfmon,任务管理器或任何类似的工具来确定内存泄漏。 它们有助于识别趋势,但不是很多。 他们以绝对术语报告的数字过于模糊和聚合,无法用于特定任务,如内存泄漏检测。

之前对这个问题的回答很好地解释了各种类型的内容。

您询问工具建议:我建议使用Memory Validator。 能够监控进行数十亿内存分配的应用程序。

http://www.softwareverify.com/cpp/memory/index.html

免责声明:我设计了Memory Validator。


#3楼

perfmon计数器的定义从一开始就被打破了,由于某种原因似乎太难以纠正。

MSDN上的视频“ 内存管理之谜 ”中提供了对Windows内存管理的一个很好的概述:它涵盖了跟踪内存泄漏所需的更多主题(例如工作集管理),但在相关主题中提供了足够的细节。


为了给你一个关于perfmon计数器描述的问题的提示,这里是关于MSDN上“ Private Bytes Performance Counter - Beware! ”的私有字节的内幕故事:

问:私有字节何时不是私有字节?

答:当它不是居民时。

Private Bytes计数器报告进程的提交费用。 也就是说,交换文件中分配的空间量,用于在交换出来时保存私有内存的内容。 注意:我避免使用“保留”一词,因为可能会混淆未提交的保留状态中的虚拟内存。


来自MSDN上的“ 性能规划 ”:

3.3私人字节

3.3.1描述

专用内存定义为为进程分配的内存,不能被其他进程共享。 当多台此类进程在计算机上执行时,此内存比共享内存更昂贵。 (传统)非托管dll中的私有内存通常由C ++静态构成,并且大约是dll总工作集的5%。


#4楼

这里有一个有趣的讨论: http//social.msdn.microsoft.com/Forums/en-US/vcgeneral/thread/307d658a-f677-40f2-bdef-e6352b0bfe9e/我对这个帖子的理解是释放小分配是没有反映在私人字节或工作集中。

长话短说:

如果我打电话

p=malloc(1000);
free(p);

那么私有字节只反映分配,而不是反释。

如果我打电话

p=malloc(>512k);
free(p);

那么私有字节正确地反映了分配和释放。

本文转载自:https://stackoom.com/question/8KB0/什么是专用字节-虚拟字节-工作集

粉丝 0
博文 1179
码字总数 0
作品 0
深圳
高级程序员
私信 提问
加载中

评论(0)

如何为 Virtual SAN 群集加力(200 万 IOPS!!!)

原文:http://blogs.vmware.com/vsphere/2014/03/supercharge-virtual-san-cluster-2-million-iops.html 现在,很多人都知道上周发布了 Virtual SAN 5.5,而且引起了轰动。在发布会上,我们公...

SDS_Revolution
2014/06/25
0
0
java虚拟机浅谈(磨砺营马剑威java)

Java虚拟机(Java Virtual Machine)简称JVM Java虚拟机是一个想象中的机器,在实际的计算机上通过软件模拟来实现。Java虚拟机有自己想象中的硬件,如处理器、堆栈、寄存器等,还具有相应的指令系...

磨砺营
2016/08/23
16
0
用 Python 编写的 Python 解释器

(点击上方公众号,可快速关注) 翻译: qingyunha 英文:Allison Kaptur http://qingyunha.github.io/taotao/ Allison是Dropbox的工程师,在那里她维护着世界上最大的由Python客户组成的网络...

Python开发者
2018/04/22
0
0
深入理解计算机系统(虚拟存储器)

虚拟存储器是硬件异常、硬件地址翻译、主存、磁盘文件和内核软件的完美交互,他为每个进程提供了一个大的、一致的和私有的地址空间。 虚拟存储器提供了三个重要的能力: 1)它将主存看成是一...

小萌兔
2015/08/06
129
2
【JVM系列】一步步解析java执行内幕

对于任何一门语言,要想达到精通的水平,研究它的执行原理(或者叫底层机制)不失为一种良好的方式。在本篇文章中,将重点研究java源代码的执行原理,即从程 序员编写JAVA源代码,到最终形成产...

java菜分享
2019/03/02
21
0

没有更多内容

加载失败,请刷新页面

加载更多

Java BigDecimal 如何去掉末尾多余的 0

Java BigDecimal 如何去掉末尾多余的 0 呢? /** * To StripTrailingZeros */ @Test public void bigDecimalStripTrailingZerosTest() { BigDecimal bi......

honeymoose
今天
43
0
齐齐哈尔哪里可以开发票-中国新闻网

齐齐哈尔哪里可以开发票【1.3.2 - 2.9.3.0 - 0.5.6.8.】李生,adb的全称为Android Debug Bridge,是Android手机通用的一个USB端口。百度CarLife的部分车机采用了该...

8315581
今天
79
0
衡水哪里可以开发票-中国新闻网

衡水哪里可以开发票【1.3.2 - 2.9.3.0 - 0.5.6.8.】李生,adb的全称为Android Debug Bridge,是Android手机通用的一个USB端口。百度CarLife的部分车机采用了该种连...

457192
今天
60
0
张家口哪里可以开发票-中国新闻网

张家口哪里可以开发票【1.3.2 - 2.9.3.0 - 0.5.6.8.】李生,adb的全称为Android Debug Bridge,是Android手机通用的一个USB端口。百度CarLife的部分车机采用了该种...

253878
今天
66
0
黑龙江哪里可以开发票-中国新闻网

黑龙江哪里可以开发票【1.3.2 - 2.9.3.0 - 0.5.6.8.】李生,adb的全称为Android Debug Bridge,是Android手机通用的一个USB端口。百度CarLife的部分车机采用了该种...

富大范
今天
39
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部