1、内存模型

1.1、堆
  1. 堆是所有线程共享的,主要存放对象实例和数组。
  2. 新生代和老年代的比例是1:2。
  3. 新生代中三个区域的比例是 8 : 1 : 1。
1.1.1、新生代

对象分配在eden区中,当eden区满时会触发minor gc,将eden区中存活的对象,复制到survivor0区中,清空eden区,当survivor0中满了时,会将存活的对象复制到survivor1区中,然后将survivor0和survivor1交换,保持survivor1是空的。每经过一次yong gc 年龄就 1。

  • Eden

    对象创建,对象分配在eden区,当eden区满了,再创建对象的时候,会触发minor gc,进行Eden和from surivior区域的垃圾回收。
  • FromServivor
  • ToSurvivor

    minor gc后还存活的对象会被放入此区域,当对象年龄到达阈值后会进入老年代。或者to surivior区域满了,会将对象放入老年代。
1.1.2、老年代
  1. 大对象,需要大量连续内存空间的对象
  2. 长期存活的对象,对象年龄超过15(默认值)
  3. yong gc后survivor区容不下的对象。
1.2、JVM栈

线程私有的,每个线程都有一个栈,主要存放当前线程的局部变量,程序运行状态,方法返回值,方法出口等。

1.3、本地方法栈

为虚拟机使用到的native方法服务。

1.4、方法区

用于存放已经被夹在的类信息,常量,静态变量,1.8后取消了永久代,增加了元空间,元空间并不在虚拟机中,而是用的是本地内存。元空间中存放类的元信息,静态变量和常量池移入堆中。

1.5、程序计数器
  1. 程序私有,生命周期与程序相同
  2. 当前线程所执行的字节码的行号指示器。
  3. 用来实现分支,循环,跳转,异常等功能。

2、常量池中包括什么

常量池在编译时期确定,存放在编译生成的class文件中,包含了基本数据类型和对象类型(String和数组)

3、如何判断对象是否存活

使用什么方法标记一个对象可回收?

  1. 引用计数法,每个对象都有一个引用计数器,被引用 1 当引用数为0即为可被GC的对象
  2. 可达性分析:从根节点出发,向下搜索,未访问到的对象标记为不可达,可被回收

4、哪些对象可以用为GC ROOT对象

  1. 虚拟机栈中引用的对象。
  2. 方法区中静态对象引用的对象。
  3. 方法区中常量引用的对象。
  4. 本地方法栈中引用的对象。

5、GC策略

  1. 标记清除法,从根节点进行扫描,对存活的对象进行标记,标记完成后,再扫描整个空间中未被标记的对象,进行清理。容易造成内存碎片
  2. 复制,将内存划分为两份,当其中一份内存满了时,从根节点扫描,将存活的对象复制到另一份内存中。不会出现内存碎片问题,但需要两倍的空间。
  3. 标记整理,如标记清除法一样,标记对象,清除后将所有存活对象向左移。避免了内存碎片和两倍空间的问题,但增加了移动对象的成本。

6、具体GC收集器

  1. 串行垃圾收集器,serial
  2. 并行垃圾收集器 parNew,parallel 注重吞吐量
  3. cms 注重最短回收停顿时间
  4. G1

cms和G1的区别 :

  • cms是新生代的垃圾收集器,采用标记清除。
  • G1是新生代和老年代的垃圾收集器,采用标记整理。
  • cms会产生内存碎片,G1并不会。
  • Cms追求最小停顿时间,G1是达到可控的停顿时间,尽可能提高吞吐量。

7、什么样的对象进入老年代

  1. 大对象,需要大量连续内存空间的对象。
  2. 长期存活的对象,对象年龄超过15(默认值)。
  3. yong Gc后survivor区容不下的对象。

8、为什么要区分新生代和老年代

  1. 对象的生存情况不同使用不同的GC算法。
  2. 新生代对象可能被频繁的创建和回收,老年代回收较少。

9、survivor区存在的意义

  1. 为了提高对象进入老年代的门槛,减少fullGC的次数,因为fullGC很耗时。
  2. 两个survivor的作用是为了减少survivor区的内存碎片。

10、什么是yangGC

对年轻代进行gc。触发条件:

  1. eden区不足

    • 清空eden from to中没被引用的对象。
    • 将eden from中存活的对象 复制到 to中。
    • 将to中的对象晋升到old中,包括两类对象,一个是年龄到达阈值,一个是to中放不下。
  2. full gc也会出发yong gc

11、什么时候触发fullGC

  1. 手动触发的GC。
  2. 老年代的空间不足。
  3. 永久代的空间满了(方法区)。
  4. 统计到yong gc晋升到老年代的平均大小大于老年代剩余的大小(老年代的空间不足)。
  5. jvm自身固定频率的fullGC(默认一小时执行一次)。

12、内存的配置参数

  1. xms xmx 配置堆内存的最小和最大值
  2. xmn 年轻代内存的初始大小
  3. xss jvm栈大小

13、对象分配内存的两种方式

  1. 指针碰撞,如果内存对象是规整的,采用指针碰撞来为对象分配内存,所有使用过的内存在指针的一侧,未使用过的内存在指针的另一侧,分配内存只需要移动指针即可。
  2. 空闲列表,内存不规整,使用过的内存和未使用过的内存交织在一起,维护一个内存使用列表,记录那些内存是可用的,在分配的时候找到一块足够大的空间划分给对象,并更新列表上的内容。

14、如何减少GC的开销

  1. 避免显示的调用System.gc。
  2. 尽量减少临时对象的使用。
  3. 对象不使用时,最好显式的置为null。
  4. 尽量使用StringBuffer而不用String累加字符串。
  5. 能用基本类型就是用基本类型。
  6. 尽量少用静态对象变量。

15、什么是JAVA内存模型(JMM)

用于屏蔽掉各种硬件和操作系统的内存访问差异,以实现让java程序在各个平台下都能达到一致的并发效果。

16、什么时happens-before

  1. 保证了内存的可见性
  2. 制定了四个规则:
  • 程序顺序规则:一个线程中的每个操作 happens-before 与后续的所有操作。
  • 监视器锁规则:一个监视器解锁 happens-before 于 加锁。
  • volatile变量规则: 写操作 happens-before 读操作。
  • 传递性 A happens-before B ,B happens-before C ,那么Ahappens-before C。

17、性能调优工具

17.1、jps

jps主要用来输出jvm中运行的进程状态信息。

-l 输出main类或者jar的权限名。

17.2、jstack

jstack pid > log

可以将线程堆栈转存到文件中。

日志分析可以使用fastthread.io。

17.3、jstat

可以显示出虚拟机进程中的classloader、内存、gc等运行数据。

参数

-class pid 类加载统计。

-gc 垃圾回收统计 ,后面跟两个参数一个是间隔输出时间,一个是总共输出次数。

gc日志可以使用 gceasy.io

17.4、jmap

jmap查看堆内存的使用情况:

jmap pid

17.5、jinfo

查看java程序的运行环境参数:

jinfo pid

18、内存栅栏

通过确保从另一个CPU来看,屏障的两边的所有指令都是正确的程序顺序,而保持程序顺序的外部可见性;其次可以实现内存数据可见性,确保内存数据会同步到CPU缓存子系统。

19、JVM产生的内存溢出及解决办法

  1. java heap space

    代码中存在大对象的分配,多次GC后仍找不到分配空间。

    解决办法:查看是否有大对象分配尤其是大数组。通过jmap把堆内存的日志dump下来,分析日志,如果解决不了增加堆内存的空间。
  2. permspace metaspace

    永久代或元空间溢出。生成大量的代理类或者使用自定义的类加载器。

    解决办法:查看有没有配置永久代或者元空间的大小。是否长时间没有重启jvm,是否有大量的反射操作。

面试【JAVA基础】JVM的更多相关文章

  1. Java基础-JVM调优策略简介

    Java基础-JVM调优策略简介 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.JVM结构分析 1>.JVM结构图 2>.JVM运行时数据区功能说明 JVM管理的内 ...

  2. 细节!重点!易错点!--面试java基础篇(二)

    今天来给大家分享一下java的重点易错点第二部分,也是各位同学面试需要准备的,欢迎大家交流指正. 1.字符串创建与存储机制:当创建一个字符串时,首先会在常量池中查找是否已经有相同的字符串被定义,其判断 ...

  3. Java基础-JVM篇

    1.1 .线程 ​ 这里所说的线程指程序执行过程中的一个线程实体.JVM 允许一个应用并发执行多个线程.Hotspot JVM 中的 Java 线程与原生操作系统线程有直接的映射关系.当线程本地存储. ...

  4. Java基础-JVM堆与栈

    首先看一个解析列子 JVM的内存空间: (1). Heap 堆空间:分配对象 new Student() (2). Stack 栈空间:临时变量 Student stu (3).Code 代码区 :类 ...

  5. Java基础-JVM内存回收

    Sun的JVMGenerationalCollecting(垃圾回收)原理是这样的:把对象分为年青代(Young).年老代(Tenured).持久代(Perm),对不同生命周期的对象使用不同的算法.( ...

  6. Java基础-JVM类加载机制

    JVM的类加载是通过ClassLoader及其子类来完成的,类的层次关系和加载顺序可以由下图来描述: 1)Bootstrap ClassLoader /启动类加载器 $JAVA_HOME中jre/li ...

  7. Java基础-JVM

    jvm=> java虚拟机 一.java虚拟机的生命周期: Java虚拟机的生命周期 一个运行中的Java虚拟机有着一个清晰的任务:执行Java程序.程序开始执行时他才运行,程序结束时他就停止. ...

  8. 细节!重点!易错点!--面试java基础篇(一)

    今天来给大家分享一下java的重点易错点部分,也是各位同学面试需要准备的,欢迎大家交流指正. 1.java中的main方法是静态方法,即方法中的代码是存储在静态存储区的. 2.任何静态代码块都会在ma ...

  9. Java基础——JVM内存结构

    推荐阅读:https://www.cnblogs.com/wangjzh/p/5258254.html 一.内存结构图 先导知识: 一个 Java 源程序文件,会被编译为字节码文件(以 class 为 ...

  10. 面试----java基础集合---------------------comparable和comparator 的区别

    comparable接口     是主要是用来自定义类存储在主要是TreeSet,TreeMap(键)集合中存储时,自定通过实现这种接口得到自然排序的功能. comparator 接口  是主要是用来 ...

随机推荐

  1. Python中匿名函数与内置高阶函数详解

    大家好,从今天起早起Python将持续更新由小甜同学从 初学者的角度 学习Python的笔记,其特点就是全文大多由 新手易理解 的 代码与注释及动态演示 .刚入门的读者千万不要错过! 很多人学习pyt ...

  2. WebApi的创建,部署,Oauth身份认证(一)

    1.首先创建一个项目 2.选择Web API 3.创建一个空的控制器 4.控制器名称为MyApiController using System; using System.Collections.Ge ...

  3. ~/.ssh/目录找不到解决方法

    执行 cd ~/.ssh发现.ssh目录找不到 原因是因为没有用root用户ssh登录过,执行一下ssh操作就会自动生成了

  4. Springboot开启事务的支持

    主要分为两步 步骤一.在main方法加上@EnableTransactionManagement注解: @SpringBootApplication @EnableTransactionManagem ...

  5. SpringBoot进阶教程(六十三)Jasypt配置文件加密

    数据库密码直接明文写在配置中,对安全来说,是一个很大的挑战.一旦密码泄漏,将会带来很大的安全隐患.尤其在一些企业对安全性要求很高,因此我们就考虑如何对密码进行加密.本文着重介绍Jasypt对Sprin ...

  6. Homekit_温湿度_人体红外_光强_传感器

    市面上大多数,传感器产品多是简单的单个传感器进行售卖,这里我推荐一款四合一的产品,使用Homekit进行控制. 前置需求: 苹果手机一台 四合一传感器一个 USB数据线一根 介绍: 1.外观上是一个小 ...

  7. MySQL查看没有主键的表

    select table_schema, table_name from information_schema.tables where table_name not in (select disti ...

  8. SpringBoot --- 自定义 Starter

    SpringBoot --- 自定义 Starter 创建 1.需要创建一个新的空工程 2.新的工程需要引入两个模块 一个Maven 模块 作为启动器 一个SpringBoot 模块 作为自动配置模块 ...

  9. 理解RESTful原理

    如何给老婆解释什么是RESTful 老婆经常喜欢翻看我订阅的技术杂志,她总能从她的视角提出很多有趣的问题. 一个悠闲的周日下午,她午觉醒来,又习惯性的抓起这个月的杂志,饶有兴趣地看了起来. 果不其然, ...

  10. 【论文总结】MapReduce论文

    摘要: MR是啥:编程模型,用户只需编写Map,Reduce两个函数,系统完成分布式计算 MR系统是啥:在大量普通计算机上实现并行化计算,系统只关心如何分割数据.大规模集群的调度.集群容错.集群通信 ...