JVM 调优和 Full GC
在对 JVM 调优的过程中,很大一部分工作就是对于 Full GC 的调节。有如下原因可能
导致 Full GC:
- 年老代(Tenured)被写满
- 永久代(Perm)被写满
- System.gc()被显式调用
- 上一次 GC 之后 Heap 的各域分配策略动态变化
开发中容易造成内存泄露的操作
内存泄漏
- 创建大量无用对象
String str = "";
for (int i = 0; i < 10000; i++) {
str += i; //相当于产生了 10000 个 String 对象
}
- 静态集合类的使用
像 HashMap、Vector、List 等的使用最容易出现内存泄露,这些静态变量的生命周期和应用程序一致,所有的对象也不能被释放。 - 各种连接对象(IO 流对象、数据库连接对象、网络连接对象)未关闭
IO 流对象、数据库连接对象、网络连接对象等连接对象属于物理连接,和硬盘或者网络连接,不使用的时候一定要关闭。 - 监听器使用不当
释放对象时,没有删除相应的监听器
其他
- 程序员无权调用垃圾回收器。
- 程序员可以调用 System.gc(),该方法只是通知 JVM,并不是运行垃圾回收器。尽量少用,会申请启动 Full GC,成本高,影响系统性能。
- Object 对象的 finalize 方法,是 Java 提供给程序员用来释放对象或资源的方法,但是尽量少用。