java7 默认垃圾回收器

本文详细介绍了在Java 7版本中如何启用G1垃圾回收器,并对比了其与CMS回收器的不同之处。通过具体的命令行参数设置及堆内存配置,展示了G1回收器的实际应用。
部署运行你感兴趣的模型镜像
java -XX:+PrintCommandLineFlags -XX:+PrintGCDetails -version
-XX:InitialHeapSize=132304640 -XX:MaxHeapSize=2116874240 -XX:ParallelGCThreads=4 -XX:+PrintCommandLineFlags -XX:+PrintGCDetails -XX:+UseCompressedOops -XX:-UseLargePagesIndividualAllocation -XX:+UseParallelGC
java version "1.7.0_01"
Java(TM) SE Runtime Environment (build 1.7.0_01-b08)
Java HotSpot(TM) 64-Bit Server VM (build 21.1-b02, mixed mode)
Heap
 PSYoungGen      total 37696K, used 1293K [0x00000007d5eb0000, 0x00000007d88c0000, 0x0000000800000000)
  eden space 32320K, 4% used [0x00000007d5eb0000,0x00000007d5ff3408,0x00000007d7e40000)
  from space 5376K, 0% used [0x00000007d8380000,0x00000007d8380000,0x00000007d88c0000)
  to   space 5376K, 0% used [0x00000007d7e40000,0x00000007d7e40000,0x00000007d8380000)
 PSOldGen        total 86144K, used 0K [0x0000000781c00000, 0x0000000787020000, 0x00000007d5eb0000)
  object space 86144K, 0% used [0x0000000781c00000,0x0000000781c00000,0x0000000787020000)
 PSPermGen       total 21248K, used 2032K [0x000000077ca00000, 0x000000077dec0000, 0x0000000781c00000)
  object space 21248K, 9% used [0x000000077ca00000,0x000000077cbfc288,0x000000077dec0000)
You don't need to enable experimental options to turn on the G1 collector any more, though:


> java -XX:+PrintCommandLineFlags -XX:+PrintGCDetails -XX:+UseG1GC -version
-XX:InitialHeapSize=132304640 -XX:MaxHeapSize=2116874240 -XX:+PrintCommandLineFlags -XX:+PrintGCDetails -XX:+UseCompressedOops -XX:+UseG1GC -XX:-UseLargePagesIndividualAllocation
java version "1.7.0_01"
Java(TM) SE Runtime Environment (build 1.7.0_01-b08)
Java HotSpot(TM) 64-Bit Server VM (build 21.1-b02, mixed mode)
Heap
 garbage-first heap   total 130048K, used 0K [0x000000077ca00000, 0x0000000784900000, 0x00000007fae00000)
  region size 1024K, 1 young (1024K), 0 survivors (0K)
 compacting perm gen  total 20480K, used 2032K [0x00000007fae00000, 0x00000007fc200000, 0x0000000800000000)
   the space 20480K,   9% used [0x00000007fae00000, 0x00000007faffc288, 0x00000007faffc400, 0x00000007fc200000)
用此方法查看我机器上的jdk7u5,发现默认默认GC还是原来的CMS,并非G1.
Oracle官方文档:
http://docs.oracle.com/javase/7/docs/technotes/guides/vm/G1.html
看来java7u4及其以后版本只是完全支持G1回收器,而非默认就是G1,如果需要使用G1还是需要添加参数 -XX:+UseG1GC
   

您可能感兴趣的与本文相关的镜像

Qwen-Image-Edit-2509

Qwen-Image-Edit-2509

图片编辑
Qwen

Qwen-Image-Edit-2509 是阿里巴巴通义千问团队于2025年9月发布的最新图像编辑AI模型,主要支持多图编辑,包括“人物+人物”、“人物+商品”等组合玩法

Java 8 中,默认垃圾回收器是 **Parallel GC(也称为吞吐量收集器)**。它是为普通应用提供高吞吐量而设计的,适用于大多数单机应用场景。 ### 回答问题: Java 8 默认使用 Parallel GC 作为其垃圾回收器。Parallel GC 包括两个主要部分: 1. **Parallel Young Generation Collector (Parallel Scavenge)**: 负责新生代垃圾回收。 2. **Parallel Old Generation Collector (Parallel Mark-Sweep)**: 负责老年代垃圾回收。 Parallel GC 的特点是通过多线程并行工作来缩短垃圾回收的暂停时间,从而提高应用程序的整体吞吐量。 --- ### 给出解释: #### Parallel GC 工作原理 - **新生代回收 (Minor GC)**: - 新生代被划分为 Eden 区和两个 Survivor 区。 - 并行收集器会将 Eden 和一个 Survivor 区中的存活对象复制到另一个 Survivor 区。 - 如果对象的年龄超过一定阈值(可以通过 `-XX:MaxTenuringThreshold` 设置),则会被晋升到老年代。 - **老年代回收 (Major GC / Full GC)**: - 当老年代空间不足时,触发 Full GC。 - 使用标记-清除算法或标记-整理算法回收老年代的对象。 #### 配置选项 - `-XX:+UseParallelGC`: 启用 Parallel GC(默认启用)。 - `-XX:ParallelGCThreads=<n>`: 设置并行垃圾回收线程数。 - `-XX:GCTimeRatio=<n>`: 设置吞吐量目标(默认值为 99,表示垃圾回收时间占比不超过 1%)。 - `-XX:MaxGCPauseMillis=<n>`: 设置最大垃圾回收暂停时间目标。 #### 示例代码 以下是一个简单的 Java 程序,展示如何通过 JVM 参数指定 Parallel GC: ```java public class ParallelGCExample { public static void main(String[] args) { System.out.println("Using Parallel GC"); // 创建大量对象以触发垃圾回收 for (int i = 0; i < 100000; i++) { new Object(); } } } ``` 运行程序时,可以通过以下命令启用 Parallel GC 并查看垃圾回收日志: ```bash java -XX:+UseParallelGC -Xlog:gc -jar ParallelGCExample.jar ``` --- ###
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值