简述 jvm 原理与工作流程

1. 内存模型  

1) 方法区 - 持久代(Permanet Generation  (线程共享)
  a. 保存方法代码(编译后的java代码)和符号表。
  b. 存放了要加载的类信息、静态变量、final类型的常量、属性和方法信息。
  c. 可通过-XX:PermSize和-XX:MaxPermSize来指定最小值和最大值。
2) 堆  (线程共享)
  a.存放实例化后对象的内存。
  b.通过-Xmx和-Xms来控制。
  c.有操作系统空闲链表遍历寻找第一个空间大于申请空间的堆节点,然后从空闲链表中移除。空间大于申请空间的部分,系统自动放回空闲链表。
3) 虚拟机栈
  a.存放基本类型的变量,对象的引用和方法调用
  b.先进后出与后进先出的规则
4) java本地栈
  虚拟机栈为虚拟机执行Java方法(字节码)服务,而本地方法栈则为虚拟机使用到的Native方法服务。
5) 程序计数器
  每个线程都有一个程序计算器,就是一个指针,指向方法区中的方法字节码(下一个将要执行的指令代码),由执行引擎读取下一条指令

2. 类加载机制

1) Bootstrap ClassLoader
  负责加载$JAVA_HOME中jre/lib/rt.jar里所有的class,由C++实现,不是ClassLoader子类
2) Extension ClassLoader
  负责加载java平台中扩展功能的一些jar包,包括$JAVA_HOME中jre/lib/*.jar或-Djava.ext.dirs指定目录下的jar包
3) App ClassLoader
  负责记载classpath中指定的jar包及目录中class
4) Custom ClassLoader
属于应用程序根据自身需要自定义的ClassLoader,如tomcat、jboss都会根据j2ee规范自行实现ClassLoader

3. 类的执行机制

JVM执行class字节码,线程创建后,都会产生程序计数器(PC)和栈(Stack),程序计数器存放下一条要执行的指令在方法内的偏移量,栈中存放一个个栈帧,每个栈帧对应着每个方法的每次调用,而栈帧又是有局部变量区和操作数栈两部分组成,局部变量区用于存放方法中的局部变量和参数,操作数栈中用于存放方法执行过程中产生的中间结果。

4. 类的实例化过程

  • 1) 子类的静态字段
  • 2) 子类的静态构造方法
  • 3) 子类的实例字段
  • 4) 父类的静态字段
  • 5) 父类的静态构造方法
  • 6) 父类的实例字段
  • 7) 父类的实例构造方法
  • 8) 子类的实例构造方法

5. gc回收机制

GC 将内存分为 年轻代、Survivor、eden

1) 标记-删除算法
   首先标记出所有需要回收的对象,标记完成后统一回收所有被标记的对象。
2) 标记-复制算法
   将可用的内存分为两块,每次只用其中一块,当这一块内存用完了,就将还存活着的对象复制到另外一块上面,然后再把已经使用过的内存空间一次性清理掉。
3) 标记整理算法
   让所有存活对象都向一端移动,然后直接清理掉边界以外的内存。
4) 分代收集算法
   基于前面三种算法的结合

6. 内存泄漏与内存溢出

内存溢出:(out of memory)通俗理解就是内存不够,通常在运行大型软件或游戏时,软件或游戏所需要的内存远远超出了你主机内安装的内存所承受大小,就叫内存溢出。
内存泄漏:(Memory Leak)是指程序中己动态分配的堆内存由于某种原因程序未释放或无法释放,造成系统内存的浪费,导致程序运行速度减慢甚至系统崩溃等严重后果。

常见的内存泄漏有:
1)静态集合类像HashMap、Vector等
2)各种连接,数据库连接,网络连接,IO连接等没有显示调用close关闭,不被GC回收导致内存泄露。
3)监听器的使用,在释放对象的同时没有相应删除监听器的时候也可能导致内存泄露。

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值