首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >为什么xmx和top之间存在内存使用上的差异?

为什么xmx和top之间存在内存使用上的差异?
EN

Stack Overflow用户
提问于 2012-08-12 13:08:43
回答 1查看 2.7K关注 0票数 2

我将jvm的xmx设置为4G,但运行一段时间后,当我使用top查看内存时,它将显示使用12G内存的进程。

那么xmx到底是什么意思呢?如果我想将jvm内存限制为4G,我该怎么办?

命令行:-server -Xms4g -Xmx4g

(另一个相关问题:)

如果发生gc,JVM将不可避免地释放不再在年轻一代中使用的对象的空间吗?或者他们中的一些人留给下一个gc?

谢谢

EN

回答 1

Stack Overflow用户

发布于 2012-08-12 14:06:05

JVM的-Xmx选项指定了maximum size of the Java garbage collected heap。它不限制JVM使用的内存大小。ps或top报告的进程的大小将包括该大小,以及进程使用的任何其他内存。以下是一些不是垃圾收集堆的一部分,但也是进程所需内存的部分内容的示例:

  • 实现JVM的代码
  • 实现JVM的数据结构的C手动堆
  • 系统中所有线程的堆栈(app + JVM)
  • 缓存Java字节码(用于库和应用程序)
  • JITed机器代码(用于库和应用程序)
  • 所有加载类的静态变量
票数 7
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/11922418

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档