jvm

作者: 我是啵啵 | 来源:发表于2020-02-06 12:43 被阅读0次

cmd java

HotSpot:

jvm 的核心组件 有个功能 就是经常编译的东西可以保存起来 类似于缓存
对class 的解析和编译

client:

默认
客户桌面级操作系统 分配的内存较小

server:

jre/lib/i386 配置文件里改顺序 jvm.cfg
分配的空间大

jvm基本结构

  • 类加载子系统:
    就包含了类加载器 加载后 放在方法区的空间
  • 方法区

  • 大小由jvm控制
    所有实例在这里创建
    所有线程共享
  • 直接内存
    受限于物理内存的大小
    在堆之外 不受限于堆 运行nio 的东西
  • 垃圾回收系统
    可以回收堆和直接内存和方法区
  • java栈
    方法压栈 保存点战争
  • 本地方法栈
    native method
    就是不同的操作系统可以调用的本地方法不同
  • pc 寄存器
    一个java 线程创建一个pc寄存器
    当前方法
    指向被执行的指令 (java方法)
    或者undefined (本地方法)
  • 执行引擎
    就是hotsport 类似
    可以即时编译

jvm 堆结构和分代

提高内存分配和垃圾回收的效率
堆的分代
新生代 老年代 永久代
堆:
young
eden +from +to


old
permanent
分代不同的垃圾回收
8 :1:1
minor gc :回收
垃圾回收达到阈值 会把from 清空 对象复制到to

垃圾回收算法

  • 引用计数 引用为0 这清除
    缺点 循环引用不能解决
  • 复制算法
    from to
    回收的 复制的 没使用的 -----to复制的
  • 标记清除法
    要暂停这个应用 产生碎片
    第一阶段 标记 有引用的对象
    第二阶段 回收空对象
  • 标记整理
    没有碎片

垃圾收集器

gc算法的实现

scavenge 次收集器

对Eden 收集
在新生代

full gc 全收集器

触发 在young 无法回收时触发
老年代的gc
System.gc()

分代回收器

在运行的时候加上 垃圾收集器可以选

新生代的
  • serial 串行 (次收集器)
  • parnew 并行收集器
    适用于 多核cpu
    缩短了暂停时间点
    是cms (老年代的一个收集器)的默认收集器
    cms ---------------parnew /serial
  • parallel scavenge
    并行 用复制算法
    提高 吞吐量 = 用户代码时间/用户代码+gc时间

老年代的
  • serial old----------------------parnew /serial/ parallel scavenge
    标记整理算法

  • parallel scavenge--------- parallel scavenge
    并行: parallel
    不包含用户线程
    并发: cms
    包含用户线程

  • cms ---------------parnew /serial

跨年代的

jvm 小工具

bin 目录下
jps -l
jps -v
看jvm 中的线程 有个pid
类是Linux中的ps
jstat
看jvm 运行时的信息
jstat -gc 3200 250 20
3200是 jps 看的线程id

image.png
jvisualvm
图形化工具
安装插件和具体参数设置在网盘ppt中

相关文章

  • 深入JVM内核 目录

    深入JVM内核 目录 深入JVM内核1 初识JVM深入JVM内核2 JVM运行机制深入JVM内核3 常用JVM配置...

  • JVM内存模型(jvm 入门篇)

    概述 jvm 入门篇,想要学习jvm,必须先得了解JVM内存模型,JVM内存模型,JVM内存模型,JVM内存模型,...

  • Jvm(一)-Java虚拟机的内存管理

    [toc] JVM JVM回顾 1. 什么是 JVM JVM是Java Virtual Machine(Java虚...

  • JVM介绍系列文章

    知晓JVM系列(一):对JVM总览知晓JVM系列(二):JVM内存管理机制与优化初探知晓JVM系列(三) :常用的...

  • 科普

    1.JVM/JRE/JDK关系JVM

  • JVM

    JVM之内存模型JVM之对象定位与访问JVM之Java垃圾回收机制JVM之类加载

  • JVM

    栈容量由-Xss指定深入理解JVM—JVM内存模型 JVM内存模型和JVM参数的关系

  • JVM基础知识系列

    JVM基础系列 JVM知识点扫盲系列(1) JVM知识点扫盲系列(2) JVM内存的那些事 JVM类加载的那些事 ...

  • (过时、作废)android 多线程 — GC

    简单解析下JVM 先说下 JVM,虽然上篇文章在讲内存时介绍了 JVM ,但是我在这里还是以 JVM 开头,JVM...

  • 技术文章罗列

    JVM JVM知识点详解JVM初步诊断JVM内存模型 Java Api java8 stream Api讲解(上)...

网友评论

      本文标题:jvm

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