- mongodb - 在 MongoDB mapreduce 中,如何展平值对象?
- javascript - 对象传播与 Object.assign
- html - 输入类型 ="submit"Vs 按钮标签它们可以互换吗?
- sql - 使用 MongoDB 而不是 MS SQL Server 的优缺点
我对 Heap、Young、Tenured 和 Perm 一代感到困惑。
谁能解释一下?
最佳答案
Java 垃圾收集器被称为通用垃圾收集器。应用程序中的对象存在不同的时间长度,具体取决于它们的创建位置和使用方式。这里的关键见解是,对短期和长期对象使用不同的垃圾收集策略可以针对每种情况专门优化 GC。
粗略地说,随着对象在年轻一代中“存活”重复的垃圾回收,它们被迁移到老一代。 永久生成是一种特殊情况,它包含 JVM 所需的对象,但不一定在程序中表示,例如表示类和方法的对象。
由于年轻一代中通常会包含大量垃圾,因此针对一次摆脱大量未使用的对象进行了优化。 Tenured Generation 因为它包含生命周期更长的对象,所以针对快速垃圾收集进行了优化,而不会浪费大量内存。
随着垃圾收集技术的改进,细节变得相当复杂,并且取决于您的 JVM 及其配置方式。您应该阅读 documentation如果您需要确切了解正在发生的事情,请针对您正在使用的特定 JVM。
也就是说,有一个简单的历史安排,这在概念层面上仍然有用。从历史上看,年轻一代将是 copy collector Tenured Generation 是 mark and sweep collector . 复制收集器基本上不需要 CPU 成本来清除垃圾,大部分成本是维护 Activity 对象,这种效率的代价是更重的内存使用。 标记和清除收集器会为 Activity 对象和未使用对象支付一些 CPU 成本,但会更有效地利用内存。
关于java - Young , Tenured 和 Perm 一代,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2070791/
作者是否建议将初始 Perm 大小和最大 Perm 大小值设置为相同的值可以防止发生完整的 GC? A memory space, either Old or Permanent, is full a
当您启动 JVM 时,PERM GEN 在哪里分配?它是主 HEAP 的一部分还是 HEAP 大小的补充。 例如,如果我使用以下参数: -server -Xms10G -Xmx10G -XX:MaxP
我正在开发一个 Tomcat 应用程序,它使用 CMS 收集器和内存条来触发 GC。当我重新加载 webapps 时,我有时会遇到这样一种情况,即老一代已满足以触发 GC,但死掉的类加载器不会被收集。
我的理解是 perm size 用于存储元数据,其中包括字节码、静态内容等。 我的问题是,反射的使用如何影响烫发大小(如果有的话)。我的意思是,如果 Program-A 使用正常的方式运行对象而 Pr
JBoss 的堆和 Perm 大小之间有任何关系吗?我想增加最大堆大小,但我不确定它会对烫发大小产生什么样的影响。我正在运行 JDK 6。目前我没有遇到永久代问题,但如果我增加堆大小,是否存在隐含关系
如果我从我的程序(一个非守护进程)创建一个守护线程,堆和永久代内存空间是与新线程共享还是重新分配? 如果守护线程有自己的空间,在创建新线程时是否考虑了 JVM 内存调整参数,如最大堆大小等? 最佳答案
这个问题在这里已经有了答案: Dealing with "java.lang.OutOfMemoryError: PermGen space" error (34 个答案) 关闭 10 年前。 我有
我想给出用户可写的主目录中所有文件的长列表(使用 ls -l),如何组合 find 和 ls -l? 最佳答案 find ~/ -maxdepth 1 -exec ls -l '{}' \; 如果您仅
p = perms([0:2]) p = 2 1 0 2 0 1 1 2 0 1 0 2 0 1 2 0
根据 https://source.android.com/devices/tech/config/uicc.html , AR-DO (E3) is extended to include PERM
我在 glassfish 服务器上部署了一个 Web 应用程序,它只包含一堆 JAX-RS REST 服务和通过 JPA 处理的数据库。我用于部署的 WAR 文件大约为 2MB,而且它的流量非常小(只
垃圾收集是否发生在 Java 堆的 PERM 区域? PERM 区域用于存储有关类、方法、变量等的元数据...还在堆的 PERM 区域中创建了字符串池,所以我相信这里不会发生垃圾回收? 最佳答案 随着
我正在调查我们的一个生产系统上的 JVM 崩溃,以下内存值在下面的 hs_err_pid 日志文件片段中代表什么? Heap par new generation total 1258624K,
我最近在升级到新的php和js sdk时遇到了问题 在下面的登录按钮工作正常之前,会弹出对话框让用户授予权限。 Connect Facebooks 现在对话框不会弹出,但是如果我取出“perms”并使
我想在我的目录中找到不可读的文件(例如带有 g-r 的文件)。所以我尝试了这个: 找到 . -perm -g-r 它显示了我所有的文件??所以我尝试了这个: 找到 . -perm -g+r 它只向我显
我不能完全理解这个参数如何影响 permutedims 函数的功能。我读了official doc for this function多次: permutedims(A::AbstractArray,
这个问题在这里已经有了答案: Grails PermGem error (4 个答案) 关闭 7 个月前。 我创建了一个 grails(2.1) 应用程序并将其部署在 tomcat 服务器上。但是我
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 这个问题似乎不是关于 a specific programming problem, a softwar
昨天我在运行 WebLogic Application Server 11g 安装程序时遇到了 OutOfMemory 错误,所以我谷歌了一下答案: java -Xms256m -Xmx512m -X
使用 Lehmer code , 任何 permutation可以使用 factorial number system 对包含 N 个元素的序列进行编码并将其映射为十进制数。 . 示例: ABCD 排
我是一名优秀的程序员,十分优秀!