分配的Java堆栈在哪里?

我在网站上注意到以下内容:JVM HotSpot内存分为3个内存空间:

  • Java堆
  • PermGen(永久代)空间
  • 原生堆(C-Heap)

在hotSpot JVM中分配的堆栈在哪里? 在本机堆中?

更新:另一个参考信息:对于64位VM,C-Heap容量=物理服务器总RAM和虚拟内存 – Java堆 – PermGen

答案是:

  1. 它取决于实现。

  2. 在我看到的实现中,线程堆栈分配由标准C本机线程库处理,看起来该库是去操作系统为堆栈分配内存段。 所以“以上都不是”。

  3. 您可以通过深入研究与您的平台相关的OpenJDK源代码来确认这一点。

UPDATE

从一个老问题,这里是pthread_create的代码片段,它请求分配线程堆栈。 此方法由JVM线程实现用于创建本机线程。

  mmap(0, attr.__stacksize, PROT_READ|PROT_WRITE|PROT_EXEC, MAP_PRIVATE|MAP_ANONYMOUS, -1, 0) 

如您所见,它只是使用mmap系统调用从操作系统请求内存段。 正如我在评论中所说,这不是常规Java堆,不是Permgen堆,也不是C本机堆。 它是操作系统特别请求的一段内存。

作为参考,这里是mmap系统调用手册条目的链接。


更新:另一个参考信息:对于64位VM,C-Heap容量=物理服务器总RAM和虚拟内存 – Java堆 – PermGen

国际海事组织,这是一个过于简单化。 (并且请提供指向您找到此信息的链接…以便我们可以以原始forms阅读。)

如果你可以通过哪种方式找到对这些东西的访问权限,那么第二个Sun(或者它现在正在使用的Oracle?)会快速发布补丁。

能够访问这些类型的东西是一个巨大的安全风险。 很多大公司的系统都使用Java。 留下一个可以追踪分配空间的洞是不可能的。

如上所述,MMAP将分配空间并将其返回以满足所需的计划和空间要求。 我几乎每天都会用MMAP做很多事情。

也许是因为我觉得事情的使用方式有点暗(为了更好地保护我的系统),相当肯定会有一个热门修复它来取消你的工作,或者你有美国队世界警察敲你的门怀疑你犯规行为,并在此过程中抓住所有装备。