1、你知道哪些可能你们线上使⽤什么GC计策?它有什么优势,适⽤于什么场景?
参考 触发JVM举办Full GC的环境及应对计策。
2、Java类加载器包罗⼏种?它们之间的⽗⼦干系是怎么样的?双亲委派机制是什么意思?有什么长处?
启动Bootstrap类加载、扩展Extension类加载、系统System类加载。
父子干系如下:
双亲委派机制:类加载器收到类加载请求,本身不加载,向上委托给父类加载,父类加载不了,再本身加载。
优势制止Java焦点API改动。具体查察:深入领略Java类加载器(ClassLoader)
3、如何⾃界说⼀个类加载器?你使⽤过哪些可能你在什么场景下需要⼀个⾃界说的类加载器吗?
自界说类加载的意义:
4、堆内存配置的参数是什么?
5、Perm Space中生存什么数据?会引起OutOfMemory吗?
加载class文件。
会引起,呈现异常可以配置 -XX:PermSize 的巨细。JDK 1.8后,字符串常量不存放在永久带,而是在堆内存中,JDK8今后没有永久代观念,而是用元空间替代,元空间不存在虚拟机中,二是利用当地内存。
具体查察Java8内存模子—永久代(PermGen)和元空间(Metaspace)
6、做GC时,⼀个工具在内存各个Space中被移动的顺序是什么?
标志排除法,复制算法,标志整理、分代算法。
新生代一般回收复制算法 GC,昆山软件公司,暮年月利用标志整理算法。
垃圾收集器:串行新生代收集器、串行老生代收集器、并行新生代收集器、并行暮年月收集器。
CMS(Current Mark Sweep)收集器是一种以获取最短接纳停即刻间为方针的收集器,它是一种并发收集器,回收的是Mark-Sweep算法。
详见 Java GC机制。
7、你有没有碰着过OutOfMemory问题?你是怎么来处理惩罚这个问题的?处理惩罚 进程中有哪些收获?
permgen space、heap space 错误。
常见的原因
详见 Java 内存溢出(java.lang.OutOfMemoryError)的常见环境和处理惩罚方法总结。
8、JDK 1.8之后Perm Space有哪些变换? MetaSpace⼤⼩默认是⽆限的么? 照旧你们会通过什么⽅式来指定⼤⼩?
JDK 1.8后用元空间替代了 Perm Space;字符串常量存放到堆内存中。
MetaSpace巨细默认没有限制,一般按照系统内存的巨细。JVM会动态改变此值。
9、jstack 是⼲什么的? jstat 呢?假如线上措施周期性地呈现卡顿,你猜疑可 能是 GC 导致的,你会怎么来排查这个问题?线程⽇志⼀般你会看个中的什么 部门?
jstack 用来查询 Java 历程的仓库信息。
jvisualvm 监控内存泄露,跟踪垃圾接纳、执行时内存、cpu阐明、线程阐明。
详见Java jvisualvm扼要说明,可参考 线上FullGC频繁的排查。
10、StackOverflow异常有没有碰着过?⼀般你揣摩会在什么环境下被触发?如何指定⼀个线程的仓库⼤⼩?⼀般你们写几多?
栈内存溢出,一般由栈内存的局部变量过爆了,导致内存溢出。呈此刻递归要领,参数个数过多,递归过深,递归没有出口。
谜底如有不正确,还请列位指正。