美文网首页
Java虚拟机

Java虚拟机

作者: juexin | 来源:发表于2017-06-21 10:22 被阅读0次

    Java运行时的数据区域
    1、堆区
    2、方法区
    3、本地方法栈
    4、虚拟机栈
    5、程序计数器
    Java运行时内存区,划分为线程私有区和线程共享区:
    (1) 线程共享区:
    -Java堆:对象分配内存的区域,这是垃圾回收的主战场
    -方法区:存放类信息、常量、静态变量、编译器编译后的代码等数据,另外还有一个常量池。当然垃圾回收也会在这个区域工作。
    (2) 线程私有区:
    -本地方法栈:虚拟机的Native方法执行的内存区
    -虚拟机栈:方法执行的内存区,每个方法执行时会在虚拟机栈中创建栈帧
    -程序计数器:记录正在执行的虚拟机字节码地址

    minor GC 与 Full GC 。分别采用哪种垃圾回收算法?简单介绍算法

    Minor GC:新生代GC,指发生在新生代的垃圾收集动作,所有的Minor GC都会触发全世界的暂停(stop-the-world),停止应用程序的线程,不过这个过程非常短暂。
    Major GC/Full GC:老年代GC,指发生在老年代的GC。

    java方法栈的作用

    java.util.concurrent 包下使用过哪些

    Java内存模型

    jvm的垃圾回收机制

    JVM的有三种垃圾回收算法,第一种为复制算法,将内存分成两部分,一部分使用,一部分未使用,垃圾回收时,将存活的对象全部复制到另一块未使用的部分,原来那部分待用;第二种是标记清除算法,这种算法在垃圾回收时只标记非存活的对象,没有复制过程,会造成内存碎片;第三种是标记整理算法,这个算法在垃圾回收时,标记非存活对象,同时将存活的对象向同一个方向移动,整理内存碎片。在Hotspot JVM中采用分代回收,在1.7之前有6中垃圾回收器,在1.7时增加了一个新的垃圾回收器Garbage First,即G1。

    标记-清除算法,分成两个阶段,第一阶段是标记出所有需要回收的对象,第二阶段是在标记完成后统一回收所有被标记的对象;缺点是会造成内存碎片。复制算法,将可用内存按容量划分为大小相等的两块,每次只使用其中的一块。当这一块的内存用完了,就将还存活的对象复制到另一块上面,然后再把已使用的内存空间一次清理掉;优点是实现简单,运行高效,缺点是内存代价太高。标记-整理算法,也分成两个阶段,第一阶段和标记-清除算法一致,第二阶段不是直接对可回收对象进行清理,而是让所有存活的对象都向一端移动,然后直接清理掉端边界以外的内存。

    如何加快gc的速度 快速判断对象生死
    JVM的分区、堆的分代以及回收算法还有OOM异常的处理思路
    JVM 的结构, GC 算法;在 HashMap 对象中不断调用 put 方法,在 JVM 中会发生什么。
    简介 JVM 的可达性分析过程。
    Out of MemoryError 产生的原因是什么,具体怎么去调优,以及理解那几个参数的含义 -Xms, -Xmx ,-Xmn,XX:PermSize

    .jvm参数调优 jvm堆的大小调优 MaxTureningShelod newratio -xxs -xxm -persize

    full gc,内存泄漏,CMS收集器

    内存区域介绍及发生OOM的情况,GC过程,描述调优过程

    刚刚说的GC Root,有哪些对象可以当做GC Root呢?

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

    假设出现了内存溢出或者栈溢出的话,怎么去解决这些问题

    内存泄漏通常有哪些可能的原因引起

    Jvm中的常用的参数有哪些

    GC,jvm调优,如果我自己定义一个String类会怎么样(双亲委派机制)

    强引用、软引用、虚引用、弱引用

    jvm内存区域和GC,finalize方法,哪些对象可以作为GC Root

    JVM 运行时的结构

    JVM:内存模型,gc,新生代老年代,对象从创建到回收的流程

    类加载过程

      JVM 中类的装载是由类加载器(ClassLoader) 和它的子类来实现的,Java 中的类加载器是一个重要的 Java 运行时系统组件,它负责在运行时查找和装入类文件中的类。
      由于 Java 的跨平台性,经过编译的 Java 源程序并不是一个可执行程序,而是一个或多个类文件。当 Java 程序需要使用某个类时,JVM 会确保这个类已经被加载、连接(验证、准备和解析)和初始化。类的加载是指把类的 .class 文件中的数据读入到内存中,通常是创建一个字节数组读入 .class 文件,然后产生与所加载类对应的 Class 对象。加载完成后,Class 对象还不完整,所以此时的类还不可用。当类被加载后就进入连接阶段,这一阶段包括验证、准备(为静态变量分配内存并设置默认的初始值)和解析(将符号引用替换为直接引用)三个步骤。最后 JVM 对类进行初始化,包括:1. 如果类存在直接的父类并且这个类还没有被初始化,那么就先初始化父类;2. 如果类中存在初始化语句,就依次执行这些初始化语句。
    类的加载是由类加载器完成的,类加载器包括:根加载器(BootStrap)、扩展加载器(Extension)、系统加载器(System)和用户自定义类加载器(java.lang.ClassLoader的子类)。从JDK 1.2开始,类加载过程采取了父亲委托机制(PDM)。PDM 更好的保证了 Java 平台的安全性,在该机制中,JVM 自带的 Bootstrap 是根加载器,其他的加载器都有且仅有一个父类加载器。类的加载首先请求父类加载器加载,父类加载器无能为力时才由其子类加载器自行加载。JVM 不会向 Java 程序提供对 Bootstrap 的引用。下面是关于几个类加载器的说明:
    

    a)Bootstrap:一般用本地代码实现,负责加载JVM基础核心类库(rt.jar);

    b)Extension:从 java.ext.dirs 系统属性所指定的目录中加载类库,它的父加载器是 Bootstrap;

    c)System:又叫应用类加载器,其父类是Extension。它是应用最广泛的类加载器。它从环境变量 classpath 或者系统属性 java.class.path 所指定的目录中记载类,是用户自定义加载器的默认父加载器。

    如何查看Jvm的内存使用情况,Jvm内存区哪里会出现溢出的问题,什么时候会导致溢出

    方法栈是否是线程私有

    哪里会内存溢出,内存溢出和内存泄露的区别,常用的jvm内存和垃圾回收检测工具

    JVM 的 GC 机制,分区、算法、对象状态等

    GC 算法? CMS 垃圾收集器, CMS 垃圾收集中断几次?

    ANR 的原因、避免。

    java 垃圾回收会出现不可回收的对象吗?怎么解决内存泄露问题?怎么定位问题源?

    OOM 的原因、避免。

    内存泄漏的原因、避免。

    类加载器、双亲委派模型、双亲实现,反双亲设计,类隔离

    JVM介绍一下,从他的编译之类,加载(忘记回答父类,子类,以及静态代码块,普通代码块的加载过程)

    平时用的Java版本是多少,我说JDK1.8,介绍一下JVM内存模型,堆怎么分代的,为什么需要分代。JDK1.8中JVM做了那些改变(主要是撤销了永久代,引入元空间)

    JVM中什么时候会进行垃圾回收,什么样的对象是可以回收的,对象从新年代到老年代的转移过程,jvm哪些地方会溢出(除了程序计数器都有)

    常用jVM调有工具有哪些(Jstatus,JStack,Jmap等)

    有哪些 JVM 调优经验

    相关文章

      网友评论

          本文标题:Java虚拟机

          本文链接:https://www.haomeiwen.com/subject/jsswqxtx.html