垃圾回收你懂,Java垃圾回收你懂吗?

开发 后端
在用 C 之类的编程语言时,程序员需要自己手动分配和释放内存。而 Java 不一样,它有垃圾回收器,释放内存由回收器负责。本文接下来将介绍Java垃圾收集的知识原理。

 Java内存区域

Q:Java虚拟机规范将JVM虚拟机所管理的内存分为几部分?如果是多选题,估计会给一些不在里面的,例如直接内存。

A:程序计数器、java虚拟机栈、本地方法栈、方法区、堆。

java对象在内存上的分配:

§ GC策略

Q:java使用根搜索算法来确定对象是否存货,哪些对象可以作为GC Roots?

A:

  •  虚拟机栈(栈帧中的本地变量表)中的引用的对象
  •  方法区中的类静态属性引用的对象
  •  方法区中的常量引用的对象
  •  本地方法栈中JNI(Native方法)的引用对象

Q:标记清除、标记整理、复制算法哪个块?

A:复制算法较快。

3个算法含义如下:

Q:SerialOld用的是什么算法?

A:标记整理算法,属于处理老年代算法。

各收集器的变化图如下,主要关注一下变化和区别,

Q:fullGC 会发生在老年代区还是新生代区?

A: 会发生在老年代区。相反,minorGC一般发送在新生代区。

新生代、老生代以及minorGC、fullGC的发生流程如下:

 

Q:方法区里的class对象(即类对象)什么时候会被回收?

A:所有实例都被回收、对应classLoader也被回收、class对象不会再被引用或者反射(这个咋确定?当初书里看到的,没懂)

§ finalized与GC

Q:什么时候会调用对象的finalized方法

A:JVM启动垃圾回收,且该对象要被回收时。

finalized应该更多是规范吧,很多规范里都要求我们不要自己实现finalized了,毕竟不确定性太大。

§ Java虚拟机GC参数配置

突然想起来当初看java虚拟机时,把那些参数给跳过了,感觉记不住。

但现在发现还是得学的,赶紧恶补一下。

Q:

-client和-server的对比

()启动较快

()性能和内存管理效率高(注意启动快和性能好不是一回事)

桌面应用一般使用(), 服务器一般使用()

A:

(-clien)启动较快

(-server)性能和内存管理效率高

桌面应用一般使用(-clien), 服务器一般使用(-server)

有4个跟内存相关的参数

-Xmn -Xms -Xmx -Xss

回答下面的问题:

Q:

用于配置java初始堆内存的是()

A:

-Xms。

-X、memory、size ,内存大小

Q:

用于配置java堆的最大值的是()

A:

-Xmx。

-X、memory、max

最大内存

Q:如果不设置,-Xms和-Xmx的大小分别默认是多少?

A:

不设置的话,二者相等,默认是 物理内存/64(小于1G)

Q:用于配置新生代内存大小的最大值是:()

你问我什么是新生代内存?

就是下面这个,1个E区加2个S区的这个内存大小

A:

-Xmn。

-X、memory、new

相类似的还有-XX:NewSize 和 -XX:MaxNewSize。

Q:如何根据上面的参数计算老年代内存大小?

A:

Xmx的值(堆最大值)- Xmn的值(新生代内存)

Q:用于配置线程栈内存的是()?替代的还有哪个参数?

A:

-Xss。另一个是-XX:ThreadStackSize

-Xss指 -X stack size

有下面3个和gc相关的参数

-Xnoclassgc -Xincgc -Xloggc:file

回答以下问题:

Q:

可用于关闭针对类对象的gc功能的是()

可用于减少gc的程序停顿时间的是()

用于输出gc相关日志的是()

A:

可用于关闭针对类对象的gc功能的是(-Xnoclassgc)

可用于减少gc的程序停顿时间的是(-Xincgc)

用于输出gc相关日志的是(-Xloggc:file)

Q:-verbose 一般是用于什么的?

A:

查询gc问题。

  •  -verbose:class 输出jvm载入类的相关信息,当jvm报告说找不到类或者类冲突时可此进行诊断。
  •  -verbose:gc 输出每次GC的相关情况,后面会有更详细的介绍。
  •  -verbose:jni 输出native方法调用的相关情况,一般用于诊断jni调用错误信息。

Q: -XX:PermSize和-XX:MaxPermSize设置的是什么内存?

A:

方法区的内存。就是最开始那个图里的这个

通过配置-XX:PermSize以及-XX:MaxPermSize来控制这块内存的大小,jvm在启动的时候会根据-XX:PermSize初始化分配一块连续的内存块,这样的话,如果-XX:PermSize设置过大,可能会很浪费。而Max如果设置小了,可能会omm。

Q:-XX:MetaspaceSize和-XX:MaxMetaspaceSize又是什么内存?

A:

元数据区内存。java8引入的,用于替代上面的perm区。

无论-XX:MetaspaceSize和-XX:MaxMetaspaceSize两个参数如何设置,随着类加载越来越多不断扩容调整,直到MetaspaceSize(如果没有配置就是默认20.8m)触发FGC,上限是-XX:MaxMetaspaceSize,默认是几乎无穷大 

 

责任编辑:庞桂玉 来源: Linux公社
相关推荐

2022-01-20 10:34:49

JVM垃圾回收算法

2017-08-04 10:53:30

回收算法JVM垃圾回收器

2022-03-21 11:33:11

JVM垃圾回收器垃圾回收算法

2009-06-25 17:48:24

Java垃圾回收

2010-12-13 11:14:04

Java垃圾回收算法

2021-11-05 15:23:20

JVM回收算法

2009-07-06 17:34:22

Java垃圾回收

2009-06-23 14:15:00

Java垃圾回收

2015-07-06 10:14:25

Java垃圾回收实战

2021-03-03 08:13:57

模式垃圾回收

2023-12-19 21:52:51

Go垃圾回收开发

2020-07-09 08:26:42

Kubernetes容器开发

2023-08-08 10:29:55

JVM优化垃圾回收

2011-06-28 12:39:34

Java垃圾回收

2015-06-04 09:38:39

Java垃圾回收机

2011-07-04 16:48:56

JAVA垃圾回收机制GC

2014-12-19 11:07:40

Java

2022-06-22 09:54:45

JVM垃圾回收Java

2009-08-21 17:31:58

C#垃圾回收

2022-10-08 18:25:22

Python内存管理GC
点赞
收藏

51CTO技术栈公众号