【面试题】GC Root都有哪些?】的更多相关文章

那天去面试,面试官问我JVM垃圾回收,我是有备而来,上来就是一个可达性分析算法,然后就是一个复制算法,标记-清理,标记-整理,以及几个常见的垃圾回收器 详情见:https://www.cnblogs.com/KeleLLXin/p/13752680.html . 按照传统面试,我已经回答完了,面试官突然问我GC Root有哪些? 不是存活的有依赖的都可以做GC Root吗?我大意了,回答的不是很好,所以今天来整理一下. 在Java语言中,GC Root主要包括以下几类元素: 1.虚拟机栈中引用的…
我们常说的垃圾回收机制中会提到GC Roots这个词,也就是Java虚拟机中所有引用的根对象.我们都知道,垃圾回收器不会回收GC Roots以及那些被它们间接引用的对象.但是,对于GC Roots的定义却不是很清楚.它们都包括哪些对象呢? 经过查阅,了解JVM中GC Roots的大致分类,然后用自己的语言解释一下: Class 由System Class Loader/Boot Class Loader加载的类对象,这些对象不会被回收.需要注意的是其它的Class Loader实例加载的类对象不…
至今为止,我基本上发现网上没有几个博客说的很明白的,今天我在这里斗胆总结一下,各位大佬,如有错误,还望指责 ^ _ ^ 首先那肯定还得是看看概念了,在JVM中,什么可以作为GC Root呢? 虚拟机栈(栈帧中的本地变量表)中引用的对象. 方法区中类静态属性引用的对象. 方法区中常量引用的对象. 本地方法栈中JNI(即一般说的Native方法)引用的对象. 如果光看概念,我**也不知道指的是个啥?所以举个栗子吧: #此处是段伪代码 class v { b,c} class b{ d} class…
(GC Root有哪些) 基本思想是通过一系列称为“GC roots”的对象作为起始点,可以作为根节点的是: 虚拟机栈(栈帧中的本地变量表)中引用的对象(即所有Java线程当前活跃的栈帧里指向GC堆里的对象的引用:换句话说,当前所有正在被调用的方法的引用类型的参数/局部变量/临时值.) 本地方法栈中JNI(即一般说的Native方法)引用的对象 方法区中类静态属性引用的对象 方法区中常量引用的对象 具体到分两代的分代式GC来说,如果第0代叫做young gen,第1代叫做old gen,那么如果…
  Question:   I have some third library code that I run and after some time I run into OutOfMemoryError. So I fired up the Eclipse MAT and analyzed the memory. Now it seems the memory can't be disposed because there is an object that is a shown as GC…
常说的GC(Garbage Collector) roots,特指的是垃圾收集器(Garbage Collector)的对象,GC会收集那些不是GC roots且没有被GC roots引用的对象.一个对象可以属于多个root,GC root有几下种:Class - 由系统类加载器(system class loader)加载的对象,这些类是不能够被回收的,他们可以以静态字段的方式保存持有其它对象.我们需要注意的一点就是,通过用户自定义的类加载器加载的类,除非相应的java.lang.Class实…
当我们的java程序遇到频繁full gc或者oom的时候,我们常常需要将当前的heap dump出来进行进一步的分析.MAT是用于分析heap dump的神器. 1 生成heap dump heap dump是jvm内存中某一时刻所有对象的的快照.通常用于定位java程序的内存泄露或者优化内存.通常可以通过以下几种方式生称dump文件: 1.1 jmap jmap -dump:[live,]format=b,file= live是可选项,如果加上了live,那么只会dump存活的对象,不会du…
为什么80%的码农都做不了架构师?>>> JVM根据GC Roots算法判定一个对象需要被回收,GC Roots一般在JVM的栈区域里产生. GC Roots原理 GC Roots基本思路就是通过一系列的称为"GC Roots"的对象作为起始点, 从这些节点开始向下搜索, 搜索所走过的路径称为引用链( Reference Chain),当一个对象到 GC Roots 没有任何引用链相连( 用图论的话来 说,就是从GC Roots到这个对象不可达)时,则证明此对象是不可…
Shallow Heap Size 指对象自身所占用的内存大小,不包含其引用的对象所占的内存大小. 1.数组类型 数组元素对象所占内存的大小总和. 2.非数组类型 对象与它所有的成员变量大小的总和.当然这里面还会包括一些Java语言特性的数据存储单元. Retained Heap Size 前对象大小+当前对象可直接或间接引用到的对象的大小总和. (间接引用的含义:A->B->C, C就是间接引用) 换句话说,Retained Size就是当前对象被GC后,从Heap上总共能释放掉的内存. 不…
题目描述     N<k时,root(N,k) = N,否则,root(N,k) = root(N',k).N'为N的k进制表示的各位数字之和.输入x,y,k,输出root(x^y,k)的值 (这里^为乘方,不是异或),2=<k<=16,0<x,y<2000000000,有一半的测试点里 x^y 会溢出int的范围(>=2000000000)  输入描述:     每组测试数据包括一行,x(0<x<2000000000), y(0<y<20000…
前言 Spring 框架自诞生以来一直备受开发者青睐,有人亲切的称之为:Spring 全家桶. 毋庸置疑,Spring 早已成为 Java 后端开发的行业标准,无数的公司选择 Spring 作为基础的开发框架,大部分Java 后端程序员在日常工作中也会接触到 Spring. 很多研发人员把 Spring 看作心目中最好的 Java 项目,没有之一. 所以这是重点也是难点,工作中必须会,面试时肯定考. Spring 面试题 1.不同版本的 Spring Framework 有哪些主要功能? 2.什…
一.什么是垃圾 内存中已经不再被使用到的空间就是垃圾 二.要进行垃圾回收,如何判断一个对象是否可以被回收? 引用计数法 很难解决对象之间的循环引用问题 枚举根节点做可达性分析 通过一系列名为"GC Roots"的对象作为起始点,从"GC Roots"对象开始向下搜索,如果一个对象到"GC Roots"没有任何引用链相连,说明此对象可以被回收. 三.哪些对象可以作为 GC Roots 的对象: 虚拟机栈中局部变量(也叫局部变量表)中引用的对象 方法…
(1)虚拟机(JVM)栈中引用对象 (2)方法区中的类静态属性引用对象   (3)方法区中常量引用的对象(final 的常量值) (4)本地方法栈JNI的引用对象…
package com.swift; import java.util.ArrayList; import java.util.Collections; import java.util.Comparator; import java.util.List; public class QuickSort { /* * 快速排序 */ public static void main(String[] args) { String[] strVoid = new String[] {"11"…
分代gc java的堆内存主要分为young generation与old generation,这两块分开回收.这就是所谓的分代gc 其中young generation又分为一个eden space与两个survivor space(From与To).默认情况下,eden space占young generation的80%,两个survivor space各占10%. young gc:新对象一般在eden space中分配,如果eden space满了,就进行一次.eden space…
source URL: http://www.infoq.com/articles/Java_Garbage_Collection_Distilled Name: Java Garbage Collection Distilled Author: Martin Thompson PostDate: 2013-06-17   翻译前言 作者还出了本关于Java性能tuning的书. 翻译这篇文章的目的是缓解上次在支付宝面试时仅回答出堆中有Young和Perm代这样的尴尬. 为自己的人生信条代言:W…
作者:请叫我红领巾,转载请注明出处http://www.cnblogs.com/xxzhuang/p/7453746.html 一.写在前面 首先,本篇文章并没有涉及原理,而是在笔者撸了<深入理解Java虚拟机>好几遍的基础上讲解自己的经验,从一个新手到现在明白JVM是个什么玩意,怎么去理解和明白,讲解这样一个经验而已.这篇文章并对JVM并没有挖掘得很深,在下目前也没有这个能力(笔者目前只是一个正在找工作的大四狗罢了),只是尽量以通熟易懂的方式,让读者理解JVM是个什么玩意.下面开始我的讲解.…
作者:请叫我红领巾,转载请注明出处http://www.cnblogs.com/xxzhuang/p/7453746.html,简书地址:http://www.jianshu.com/p/b963b3c0ad53 一.写在前面 首先,本篇文章并没有涉及原理,而是在笔者撸了<深入理解Java虚拟机>好几遍的基础上讲解自己的经验,从一个新手到现在明白JVM是个什么玩意,怎么去理解和明白,讲解这样一个经验而已.这篇文章并对JVM并没有挖掘得很深,在下目前暂时也没有这个能力,只是以通熟易懂的方式,让读…
摘要:java内存dump是jvm运行时内存的一份快照,利用它可以分析是否存在内存浪费,可以检查内存管理是否合理,当发生OOM的时候,可以找出问题的原因.那么dump文件的内容是什么样的呢? JVM dump java内存dump是jvm运行时内存的一份快照,利用它可以分析是否存在内存浪费,可以检查内存管理是否合理,当发生OOM的时候,可以找出问题的原因.那么dump文件的内容是什么样的呢?我们一步一步来 获取JVM dump文件 获取dump文件的方式分为主动和被动 i.主动方式:1.利用jm…
三.垃圾回收 1.如何判断对象可以回收 引用计数法 弊端:循环引用时,两个对象的计数都为1,导致两个对象都无法被释放 可达性分析算法 JVM中的垃圾回收器通过可达性分析来探索所有存活的对象 扫描堆中的对象,看能否沿着GC Root对象为起点的引用链找到该对象,如果找不到,则表示可以回收 可以作为GC Root的对象 虚拟机栈(栈帧中的本地变量表)中引用的对象. 方法区中类静态属性引用的对象 方法区中常量引用的对象 本地方法栈中JNI(即一般说的Native方法)引用的对象 五种引用 强引用 只有…
三.垃圾回收 3.1.如何判断对象可以回收 3.1.1 引用计数法 弊端:循环引用时,两个对象的计数都为1,导致两个对象都无法被释放 3.1.2 可达性分析算法 JVM中的垃圾回收器通过可达性分析来探索所有存活的对象 扫描堆中的对象,看能否沿着GC Root对象为起点的引用链找到该对象,如果找不到,则表示可以回收 可以作为GC Root的对象(使用eclipse的Java Memory Analyzer工具(MAT)分析哪些是gc root ) 虚拟机栈(栈帧中的本地变量表)中引用的Java对象…
一. Java 类加载过程? Java 类加载需要经历一下 7 个过程: 1. 加载 加载是类加载的第一个过程,在这个阶段,将完成一下三件事情: • 通过一个类的全限定名获取该类的二进制流. • 将该二进制流中的静态存储结构转化为方法去运行时数据结构. • 在内存中生成该类的 Class 对象,作为该类的数据访问入口. 2. 验证 验证的目的是为了确保 Class 文件的字节流中的信息不回危害到虚拟机.在该阶段主要完成以下四钟验证: • 文件格式验证:验证字节流是否符合 Class 文件的规范,…
转自:http://jeromecen1021.blog.163.com/blog/static/18851527120117274624888/ 面试题目: 地球人都知道,Java有个东西叫垃圾收集器,它让创建的对象不需要像c/cpp那样delete.free掉,你能不能谈谈,GC是在什么时候,对什么东西,做了什么事情? 一.回答:什么时候? 1.系统空闲的时候. 分析:这种回答大约占30%,遇到的话一般我就会准备转向别的话题,譬如算法.譬如SSH看看能否发掘一些他擅长的其他方面. 2.系统自…
面试题目:地球人都知道,Java有个东西叫垃圾收集器,它让创建的对象不需要像c/cpp那样delete.free掉,你能不能谈谈: GC是在什么时候,对什么东西,做了什么事情? 以上算是三个问题,下面逐一分析: 问题一回答:什么时候?1.系统空闲的时候.    分析:这种回答大约占30%,遇到的话一般我就会准备转向别的话题,譬如算法.譬如SSH看看能否发掘一些他擅长的其他方面. 2.系统自身决定,不可预测的时间/调用System.gc()的时候.    分析:这种回答大约占55%,大部分应届生都…
今天看到一个gc面试题,觉得挺有意思的,写下来,给自己留个印象 GC是在什么时候,对什么东西,做了什么事情? 1.什么时候 a.系统空闲的时候 b.系统自身决定,不可预测的时候调用gc c.eden区满了调用minor gc(),升级到老年代的对象大于老年代剩余空间调用full gc() d.程序员不能具体控制时间,系统在不可预测的时间调用System.gc()函数的时候:当然可以通过调优,用NewRatio控制newObject和oldObject的比例,用MaxTenuringThresho…
问题:Object的finaliz()方法 的作用是否与C++的析构函数作用相同? --->不同的 1.C++的析构函数调用确定,就是对象离开作用域之后就马上被删除.而java Object的finaliz()调用之后,具有不确定性. 2.将未被引用的对象放置于F-Queue队列(当垃圾回收器要宣告一个对象要死亡的时候,至少要经过2次标记过程,如果对象经过了可达性分析算法之后,发现没有跟GC ROOT有相连的引用链,就被会第一次标记,并判断是否执行finaliz方法,如果 对象覆盖了finali…
一.Java基础 1. String类为什么是final的. 2. HashMap的源码,实现原理,底层结构. 3. 说说你知道的几个Java集合类:list.set.queue.map实现类咯... 4. 描述一下ArrayList和LinkedList各自实现和区别 5. Java中的队列都有哪些,有什么区别. 6. 反射中,Class.forName和classloader的区别 7. Java7.Java8的新特性(baidu问的,好BT) 8. Java数组和链表两种结构的操作效率,在…
一.Java基础 1. String类为什么是final的. 2. HashMap的源码,实现原理,底层结构. 3. 说说你知道的几个Java集合类:list.set.queue.map实现类咯... 4. 描述一下ArrayList和LinkedList各自实现和区别 5. Java中的队列都有哪些,有什么区别. 6. 反射中,Class.forName和classloader的区别 7. Java7.Java8的新特性(baidu问的,好BT) 8. Java数组和链表两种结构的操作效率,在…
一.Java基础 1.String类为什么是final的. 2.HashMap的源码,实现原理,底层结构. 3.说说你知道的几个Java集合类:list.set.queue.map实现类咯... 4.描述一下ArrayList和LinkedList各自实现和区别 5.Java中的队列都有哪些,有什么区别. 6.反射中,Class.forName和classloader的区别 7.Java7.Java8的新特性(baidu问的,好BT) 8.Java数组和链表两种结构的操作效率,在哪些情况下(从开…