[GC [DefNew
Desired survivor size 524288 bytes, new threshold 1 (max 1)
- age 1: 415288 bytes, 415288 total
: 4695K->405K(9216K), 0.0064338 secs] 4695K->4501K(19456K), 0.0064885 secs] [Times: user=0.00 sys=0.00, real=0.00 secs]
[GC [DefNew
Desired survivor size 524288 bytes, new threshold 1 (max 1)
- age 1: 136 bytes, 136 total
: 4665K->0K(9216K), 0.0013172 secs] 8761K->4501K(19456K), 0.0013602 secs] [Times: user=0.00 sys=0.02, real=0.02 secs]
Heap
def new generation total 9216K, used 4260K [0x315e0000, 0x31fe0000, 0x31fe0000)
eden space 8192K, 52% used [0x315e0000, 0x31a08fe0, 0x31de0000)
from space 1024K, 0% used[0x31de0000, 0x31de0088, 0x31ee0000)
to space 1024K, 0% used [0x31ee0000, 0x31ee0000, 0x31fe0000)
tenured generation total 10240K, used 4501K [0x31fe0000, 0x329e0000, 0x329e0000)
the space 10240K, 43% used[0x31fe0000, 0x32445578, 0x32445600, 0x329e0000)
以MaxTenuringThreshold=15运行输出日志
[GC [DefNew
Desired survivor size 524288 bytes, new threshold 15 (max 15)
- age 1: 415288 bytes, 415288 total
: 4695K->405K(9216K), 0.0064799 secs] 4695K->4501K(19456K), 0.0065357 secs] [Times: user=0.00 sys=0.00, real=0.00 secs]
[GC [DefNew
Desired survivor size 524288 bytes, new threshold 15 (max 15)
- age 1: 136 bytes, 136 total
- age 2: 415080 bytes, 415216 total
: 4665K->405K(9216K), 0.0011127 secs] 8761K->4501K(19456K), 0.0011722 secs] [Times: user=0.01 sys=0.00, real=0.02 secs]
Heap
def new generation total 9216K, used 4665K [0x315e0000, 0x31fe0000, 0x31fe0000)
eden space 8192K, 52% used [0x315e0000, 0x31a08fe0, 0x31de0000)
from space 1024K, 39% used[0x31de0000, 0x31e455f0, 0x31ee0000)
to space 1024K, 0% used [0x31ee0000, 0x31ee0000, 0x31fe0000)
tenured generation total 10240K, used 4096K [0x31fe0000, 0x329e0000, 0x329e0000)
the space 10240K, 40% used[0x31fe0000, 0x323e0010, 0x323e0200, 0x329e0000)
在方法testMaxTenuringThreshold()中,对象allocation1需要256KB的内存空间。当MaxTenuringThreshold=1时,allocation1对象在第二次GC发生时进入老年,新生代的Survivor空间变为0KB。
当MaxTenuringThreshold=15时,allocation1对象在第二次GC发生时仍然留在新生代,新生代的Survivor空间变为404KB
动态对象年龄判定
为了能更好地适应不同程序的内存情况,虚拟机并不总是要求对象的年龄必须达到MaxTenuringThreshold才能晋升老年代。如果在Survivor空间中相同年龄所有对象大小的总和大于Survivor空间的一半,年龄大于或等于该年龄的对象就可以直接进入老年代,无须等到MaxTenuringThreshold要求的年龄。
运行下面代码并输出GC日志
输出GC日志
[GC [DefNew
Desired survivor size 524288 bytes, new threshold 1 (max 15)
- age 1: 677448 bytes, 677448 total
: 4951K->661K(9216K), 0.0066603 secs] 4951K->4757K(19456K), 0.0067187 secs] [Times: user=0.00 sys=0.00, real=0.00 secs]
[GC [DefNew
Desired survivor size 524288 bytes, new threshold 15 (max 15)
- age 1: 136 bytes, 136 total
: 4921K->0K(9216K), 0.0014790 secs] 9017K->4757K(19456K), 0.0015298 secs] [Times: user=0.00 sys=0.00, real=0.00 secs]
Heap
def new generation total 9216K, used 4260K [0x315e0000, 0x31fe0000, 0x31fe0000)
eden space 8192K, 52% used [0x315e0000, 0x31a08fe0, 0x31de0000)
from space 1024K, 0% used[0x31de0000, 0x31de0088, 0x31ee0000)
to space 1024K, 0% used [0x31ee0000, 0x31ee0000, 0x31fe0000)
tenured generation total 10240K, used 4757K [0x31fe0000, 0x329e0000, 0x329e0000)
the space 10240K, 46% used[0x31fe0000, 0x32485588, 0x32485600, 0x329e0000)
在日志中,我们发现Survivor空间的使用率为0,也就是说allocation1,allocation2对象都进入到了老年代中,而没有等到15岁的年龄。
相关推荐
Java虚拟机(JVM)的内存管理机制是Java编程中至关重要的部分,它涉及到程序的性能和稳定性。本文主要分析了Java虚拟机的内存管理,特别是垃圾回收机制及其实现。 首先,Java虚拟机中的内存主要分为堆内存和栈内存...
Java虚拟机内存管理总结 Java虚拟机(JVM)中的内存管理是指Java语言中对象的分配和释放问题。Java中的内存管理可以分为两部分:对象的分配和释放。 对象的分配是由程序完成的,程序员需要通过关键字new为每个对象...
本文档旨在对Sun J2SE 5.0版本中的Java HotSpot虚拟机(JVM)内存管理机制进行全面概述,包括不同类型的内存收集器及其配置方法、如何调整收集器内存区域的大小等。此外,还将提供一些影响内存收集器行为的常见选项,...
- **垃圾收集(Garbage Collection, GC)**:自动内存管理,清理不再使用的对象,防止内存泄漏。包括新生代GC(Minor GC)、老年代GC(Major GC)和全GC(Full GC)。 - **内存溢出与内存泄漏**:当内存耗尽或无法...
例如,对JVM的垃圾回收算法的了解,有助于开发者编写出更适合自动内存管理的代码。了解JVM的线程模型,有助于编写高性能的多线程程序。 JVM规范是不断发展的,随着Java技术的发展,它也在不断地进行改进和扩展。...
- 堆内存是所有线程共享的,由Java虚拟机自动管理。 - 堆内存的大小可以通过JVM参数来设置,如`-Xms`和`-Xmx`来指定初始大小和最大限制。 3. **数据段(Data Segment)**: - 包括静态域和常量池两部分。 - **...
3. **垃圾收集与内存管理**:JVM负责自动管理内存,包括对象的分配和回收。垃圾收集器是其重要组成部分,通过标记-清除、复制、标记-整理和分代收集等多种算法来释放不再使用的内存。 4. **类加载过程**:类的生命...
垃圾收集自动管理内存,避免程序员手动处理内存泄露问题;JIT编译则是在运行过程中将频繁执行的热点代码编译成本地机器码,提升运行效率。 总的来说,Java虚拟机是Java生态系统中的关键组件,它使得Java程序能够在...
此外,JVM还实现了垃圾回收机制,自动管理内存,避免了程序员手动管理内存的麻烦。 JVM还有许多优化技术,如分代垃圾收集、并行/并发GC、压缩引用、逃逸分析等,这些都对提升Java应用的性能起到了关键作用。对于...
3. **垃圾收集与内存管理**:Java虚拟机中的垃圾收集机制是自动进行内存管理的关键。书里介绍了不同的垃圾收集算法(如标记-清除、复制、标记-整理、分代收集等)以及垃圾收集器(如Serial、ParNew、CMS、G1等),...
JAVA虚拟机的内存分配与回收机制是JAVA语言的核心机制之一,栈和堆是JAVA用于在RAM中存放数据的地方,JAVA自动管理栈和堆,程序员不能直接地设置栈或堆。堆是由垃圾回收来负责的,堆的优势是可以动态地分配内存大小...
JAVA虚拟机内存分配机制是Java程序执行过程中内存管理的核心部分,它涉及到程序的性能和效率。Java虚拟机(JVM)内存主要分为两大部分:栈内存和堆内存。 栈内存主要存储程序运行过程中的局部变量,包括基本类型...
同时,ART也提供了垃圾回收和内存管理机制,有助于提高应用的稳定性和效率。 3. **JAVA虚拟机的执行过程** 在Android中,Java源代码首先通过编译器生成.class文件,然后通过dx工具转换为.dex文件。在设备上,ART会...
此外,JVM的垃圾收集机制是其内存管理的关键,它自动回收不再使用的对象,避免内存泄漏。 为了更好地理解和分析JVM行为,开发者通常会借助各种工具,如VisualVM、JProfiler和JConsole等。这些工具可以实时监控JVM的...
2. **内存保护**:通过内存管理机制,JVM可以防止程序访问非法内存区域,避免内存泄漏和其他内存相关的问题。 3. **数据流分析**:字节码验证器会进行数据流分析,确保所有变量在使用前已经被正确初始化。 4. **...
它详细阐述了Java虚拟机(JVM)的工作原理,包括内存管理、类加载机制、字节码执行以及垃圾回收等核心概念。深入理解这些知识点对于提升程序性能、解决运行时问题以及设计高效的应用程序至关重要。 1. **JVM架构** ...
4. 内存管理:主要涉及垃圾收集机制,自动回收不再使用的对象,避免内存泄漏。现代JVM使用多种垃圾收集算法,如标记-清除、复制、标记-整理和分代收集等。 5. 本地方法接口:允许JVM调用原生的C/C++代码,实现与...
Java语言丰富的类库支持、自动内存管理和跨平台执行能力是其显著的优势,使得Java语言在互联网、企业网和嵌入式设备等领域广泛应用。JVM通过其解释执行机制和即时编译技术,使得Java程序具备了良好的平台无关性和...