java JVM GC 笔记(个人对GC 或JVM 的了解)

JVM 是在操作系统上的一个平台,与操作系统间有个装换器,将字节码文件转换成对应平台的机器码,字节码文件从编译器编译.java文件产生。

JVM的结构 栈(存放的就是方法的引用,局部变量,方法体)、堆(常量,方法的实例)、方法区(常量池、静态方法区)、程序计数器、本地方方法栈(不受虚拟机限制的本地方法栈区)

有一张图挺详细的

https://blog.csdn.net/Marvel__Dead/article/details/69220153?locationNum=5&fps=1

用户编写的java文件通过jvm的类加载器加载进内存

 

编译优化的技术

  • 方法内联,去除方法调用成本,
  • 冗余访问消除
  • 复写传播
  • 无用代码消除
  • 公共子表达式消除,没必要重复计算公共子表达式的值
  • 数组边界检查消除
  • 逃逸分析,分析对象的动态作用域,一个对象定以后,被外部方法调用,称为方法逃逸,被其他线程访问到,称为线程逃逸
    • 栈上分配
    • 同步消除
    • 标量替换

 

 类加载器:

bootstrap(根类加载器)加载JVM自身类

extension(扩展类加载器)加载lib下的jar包

system(系统类加载器)加载用户编写的java文件

JVM加载类是按需加载 使用双亲委派模式

双亲委派模式:

当某个类加载器收到类加载的请求时不会自己直接加载 而是先去找父类加载器 当父类加载器还有父类时一直向上请求 直到根节点根类加载器;然后向下返回 当父类加载器能加载时 成功返回,不能加载就交由子类尝试加载

类加载机制 :  加载  验证  准备 解析  初始化 运行 狗带

 

 

 

GC 

JVMGC

GC主要发生在堆内存中 现在采用为分代回收 

判断对象是否是要回收的对象有可达性分析 和引用计数等

引用计数:新增一个引用计数+1 引用被释放计数-1当计数为0则代表对象可回收  (此方法过时)

可达性分析:从GC Root开始 当一个对象和GC Root没有间接或者直接的引用链时(么有直接或者间接的引用关系) 该对象不可用

GC Root包括:1、虚拟机栈中引用的对象。2、方法区中类静态属性实体引用的对象。3、方法区中常量引用的对象。4、 本地方法栈中JNI引用的对象。

分代回收:JVM中分为3个大区 年轻代 老年代 永久代(堆外内存)而大区中又有小区   所有的新生对象都是放在年轻代中 当区块中满了时会将还存存活的对象(没有被GC掉的)移到下个区块

 

posted @ 2018-08-01 10:14  随风扶柳  阅读(215)  评论(0编辑  收藏  举报