栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

了解JVM内存分配和Java内存不足:堆空间

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

了解JVM内存分配和Java内存不足:堆空间

JVM如何实际为自己分配内存?

对于堆,它分配一个最大大小的连续大内存区域。最初是虚拟内存,但是随着时间的流逝,它变成了在操作系统的控制下所使用部分的真实内存

这与OS如何将可用内存传递给JVM有什么关系?

JVM对操作系统中的可用内存一无所知。

或更笼统地说,任何进程的内存分配实际上如何工作?

通常,它使用malloc和free。

虚拟内存如何发挥作用?

最初分配虚拟内存,然后将其转换为实际使用的内存。这对于任何过程都是正常的。

假设您有一个具有32GB物理内存的系统,并且已将所有32GB分配给Java进程。

你不能 操作系统需要一些内存,并且将有其他用途的内存。即使在JVM内,堆也仅是所使用内存的一部分。如果您有32 GB的内存,我建议最大为24 GB的堆。

假设您的进程实际上消耗了所有32GB的内存,

假设您有48 GB,然后启动一个使用32 GB主内存的进程。

我们如何强制该过程使用虚拟内存而不是遇到OOM异常?

该应用程序从一开始就使用虚拟内存。您不能使堆太大,因为如果堆开始交换,您的计算机(而不仅仅是应用程序)将变得不可用。

通过仔细使用堆外内存,可以使用比物理内存更多的内存。但是,托管内存必须位于物理内存中,因此,如果需要32 GB的堆,请购买64 GB的主内存。



转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/486813.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号