jvm笔记

参考资料:黑马程序员JVM完整教程;深入理解java虚拟机

一、jvm是什么

1、定义

Java Virtual Machine,JAVA程序的运行环境(JAVA二进制字节码的运行环境)

2、好处

  • 一次编写,到处运行
  • 自动内存管理,垃圾回收机制
  • 数组下标越界检查
  • 动态

3、JVM JRE JDK的关系

4、jvm整体架构

二、内存结构

1、程序计数器

作用

当前线程所执行的字节码的行号指示器。字节码解释器工作时就是改变程序计算器的值来选取下条需要执行的字节码指令,它是程序控制流的指示器,分支、循环、跳转、异常处理、线程恢复等基本功能都需要依赖计数器来完成。

特点

  • 线程私有
    • CPU会为每个线程分配时间片,当当前线程的时间片使用完以后,CPU就会去执行另一个线程中的代码
    • 程序计数器是每个线程私有的,当另一个线程的时间片用完,又返回来执行当前线程的代码时,通过程序计数器可以知道应该执行哪一句指令
  • 不存在内存溢出

2、Java虚拟机栈

基本内容

  • 每个线程创建时都会创建一个虚拟机栈,内部存储一个个栈帧,对应一次次方法的调用

  • 生命周期和线程一致,线程私有

  • 栈帧中局部变量表中存储基本数据类型、对象引用、returnAddress类型

  • 每个线程只有一个活动栈帧。

两类异常状况

  • 如果线程请求深度大于虚拟机所允许的深度,会抛出StackOverflowError
    • 虚拟机栈中,栈帧过多(无限递归)
    • 每个栈帧所占用过大
  • 如果虚拟机栈容量可以动态扩展,当前扩展时无法申请到足够的内存,会抛出OutOfMemoryError

特点

  • 快速有效的存储方式,仅次于程序计数器
  • jvm对java栈的操作只有两个:每个方法执行的如栈和方法执行完的出栈
  • 不存在垃圾回收

基础参数

  • -Xss 调整线程中栈的大小

问题辨析

  • 垃圾回收是否涉及栈内存?
    • 不需要。因为虚拟机栈中是由一个个栈帧组成的,在方法执行完毕后,对应的栈帧就会被弹出栈。所以无需通过垃圾回收机制去回收内存。
  • 栈内存的分配越大越好吗?
    • 不是。因为物理内存是一定的,栈内存越大,可以支持更多的递归调用,但是可执行的线程数就会越少。
  • 方法内的局部变量是否是线程安全的?
    • 如果方法内局部变量没有逃离方法的作用范围,则是线程安全
    • 如果如果局部变量引用了对象,并逃离了方法的作用范围,则需要考虑线程安全问题

线程运行诊断

CPU占用过高

  • Linux环境下运行某些程序的时候,可能导致CPU的占用过高,这时需要定位占用CPU过高的线程
    • top命令,查看是哪个进程占用CPU过高
    • ps H -eo pid, tid(线程id), %cpu | grep 刚才通过top查到的进程号 通过ps命令进一步查看是哪个线程占用CPU过高
    • jstack 进程id 通过查看进程中的线程的nid,刚才通过ps命令看到的tid来对比定位,注意jstack查找出的线程id是16进制的需要转换

3、本地方法栈

本地方法栈和java虚拟机栈发挥的作用非常相似,其区别主要是虚拟机栈为虚拟机执行java方法(也就是字节码)提供服务,而本地方法栈是虚拟机使用本地(native)方法服务。

4、java堆

定义

  • Java堆是虚拟机所管理的内存中最大的一块,被所有线程共享,虚拟机启动时创建,存放对象实例(通过new关键字创建的对象都会被放在堆内存

特点

  • 所有线程共享,堆内存中的对象都需要考虑线程安全问题
  • 有垃圾回收机制

堆内存溢出

java.lang.OutofMemoryError :java heap space. 堆内存溢出

堆内存诊断

jps:查看当前系统中有哪些java进程

jmap -heap:查看堆内存占用情况

jconsole:图形检测工具

jvirsalvm

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值