JVM内存管理

1.JVM的位置
在这里插入图片描述
2.JVM的体系结构
在这里插入图片描述
3.类加载器

  • 虚拟机自带的加载器
  • 启动类(根)加载器
  • 扩展类加载器
  • 应用程序加载器

4.双亲委派机制

  • 什么是双亲委派机制 : 当某个类加载器需要加载某个.class文件时,它首先把这个任务委托给他的上级类加载器,递归这个操作,如果上级的类加载器没有加载,自己才会去加载这个类。
  • 双亲委派机制的作用
    1、防止重复加载同一个.class。通过委托去向上面问一问,加载过了,就不用再加载一遍。保证数据安全。
    2、保证核心.class不能被篡改。通过委托方式,不会去篡改核心.clas,即使篡改也不会去加载,即使加载也不会是同一个.class对象了。不同的加载器加载同一个.class也不是同一个Class对象。这样保证了Class执行安全。
  • 过程
    1.类加载器收到类加载的请求!
    2.将这个请求向上委托给父类加载器去完成,一直向上委托,知道启动类加载器
    3.启动加载器检查是否能够加载当前这个类,能加较就结束,使用当前的加载器,否则,抛出异常,通知子加载器进行加较
    4.重复步骤3

5.沙箱安全机制
Java安全模型的核心就是Java沙箱,沙箱是一个限制程序运行的环境。沙箱机制就是将jJava代码限定在虚拟机(JVM)特定的运行范围中,并且严格限制代码对本地系统资源访问,通过这样的措施来保证对代码的有效隔离,防止对本地系统造成破坏。所有的Java程序运行都可以指定沙箱,可以定制安全策略。
在Java中将执行程序分成本地代码和远程代码两种,本地代码默认视为可信任的,而远程代码则被看作是不受信的。授信的本地代码可以访问一切本地资源。而非授信的远程代码在早期的Java实现中,安全依赖于沙箱机制。
6.Native

  • 带了native 关键字说明java的作用范围达不到了,会去调用底层C语言的库
  • 会进入本地方法栈
  • 调用本地方法本地接口JNI
  • JNI作用:扩展Java的使用,融合不同的编程语言为Java所用
  • 它在内存区域中专门开辟了一块标记区域:Native Method Stack,登记native方法
  • 在最终执行的时候,加载本地方法库中的方法通过JNI

7.PC寄存器

  • 程序计数器:Program Counter Register
    每个线程都有一个程序计数器,是线程私有的,就是一个指针,指向方法区中的方法字节码(用来存储指向像一条指令的地址,也即将要执行的指令代码),在执行引擎读取下一条指令,是一个非常小的内存空间,几乎可以忽略不计

8.方法区

  • 方法区是被所有线程共享,所有字段和方法字节码,以及一些特殊方法,如构造函数,接口代码也在此定义,简单说,所有定义的方法的信息都保存在该区域,此区域属于共享区间;
  • 静态变量、常量、类信息(构造方法、接口定义)、运行时的常量池存在方法区中,但是实例变量存在堆内存中,和方法区无关

9.栈(一种数据结构)

  • 特点 : 先进后出、后进先出:桶
  • 栈内存,主管程序的运行,生命周期和线程同步;线程结束,栈内存也就是释放,对于栈来说,不存在垃圾回收问题,一旦线程结束,栈就结束
  • 栈:8大基本类型+对象引用+实例的方法
  • 栈运行原理:栈帧
  • 栈满了: StackOverflowError

10.三种JVM : SUN、BEA和IBM
11.堆(Heap)

  • 一个JVM只有一个堆内存,堆内存的大小是可以调节的。
  • 类加载器读取了类文件后,一般会把类,方法,常量,变量放到堆中,保存所有引用类型的真实对象;
  • 堆内存中还要细分为三个区域:
    新生区(伊甸园区)Young/New
    养老区 old
    永久区Perm

12.新生区(伊甸园区、幸存区0区、幸存区1区)、老年区

  • GC垃圾回收,主要是在伊甸园区和养老区
  • 新生区
    类:诞生和成长的地方,甚至死亡;
    伊甸园,所有的对象都是在伊甸园区new出来的!
    幸存者区(0,1)

13.永久区

  • 这个区域常驻内存的。用来存放IDK自身携带的Class对象。Interface元数据,存储的是Java运行时的一些环境或类信息,这个区域不存在垃圾回收!关闭VM虚拟就会释放这个区域的内存~
  • 一个启动类,加载了大量的第三方jar包。Tomcat部署了太多的应用,大量动态生成的反射类。不断的被加载。直到内存满,就会出现OOM;
    jdk1.6之前︰永久代,常量池是在方法区;
    jdk1.7 : 永久代,但是慢慢的退化了,去永久代,常量池在堆中
    jdk1.8之后 : 无永久代,常量池在元空间
    在这里插入图片描述

14.GC

  • JVM在进行GC时,并不是对这三个区域统一回收。大部分时候,回收都是新生代
  • GC两种类:轻GC(普通的GC),重GC(全局GC)
  • 常用算法
    1.标记清除法 :
    扫描这些对象:对活着对象进行标记
    清除:对没有标记的对象,进行清除
    优点:不需要额外的空间!
    缺点:两次扫描,严重浪费时间,会产生内存碎片。
    2.复制算法 :
    最佳使用场景:对象存活度较低的时候 : 新生区
    3.标记压缩 再优化:
    压缩:防止内存碎片产生,再次扫描,向一段移动存活的对象
    多了一个移动成本
  • 没有最好的算法,只有最合适的算法-----> GC∶分代收集算法
    年轻代 : 存活率低----复制算法!
    老年代 :
    区域大 : 存活率
    标记清除(内存碎片不是太多) + 标记压缩混合实现

15.JMM

  • 作用:缓存一致性协议,用于定义数据读写的规则。
  • JMM定义了线程工作内存和主内存之间的抽象关系 : 线程之间的共享变量存储在主内存(Main Memory)中,每个线程都有一个私有的本地内存(Local Memory)
    在这里插入图片描述
    16.总结
  • 内存效率 : 复制算法 > 标记清除算法 > 标记压缩算法(时间复杂度)
  • 内存整齐度 : 复制算法 = 标记压缩算法 > 标记清除算法
  • 内存利用率 : 标记压缩算法 = 标记清除算法 > 复制算法
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值