JVM和类加载机制-01[JVM底层架构和JVM调优]

news/2024/8/22 18:15:42 标签: jvm

JVM底层

  • Java虚拟机内存模型
    • JVM组成部分
      • 五大内存区域各自的作用
        • 虚拟机栈(线程栈)
          • 栈帧内存区域
        • 本地方法栈
        • 程序计数器
          • 为什么jvm要设计程序计数器?
        • 方法区
  • JVM优化-堆详解
    • JVM底层垃圾回收机制
    • jvm调优工具
      • jvisualvm.exe
      • Arthas工具使用

Java虚拟机内存模型

  • JVM跨平台原因
    就是在JVM层面对各个操作系统的指令做了不同处理
    在这里插入图片描述

JVM组成部分

在这里插入图片描述

五大内存区域各自的作用

虚拟机栈(线程栈)

每次运行的时候,都会给线程栈分配一部分内存,有多少个线程就分配多少个。来存放各自线程运行时的变量,说白了就是工作内存,工作内存哪里来的就是虚拟机栈中分配来的
在这里插入图片描述

栈帧内存区域

一个方法对应一个栈帧内存区域,
在这里插入图片描述
在这里插入图片描述

本地方法栈

方法执行到了本地方法,本地方法执行也需要内存空间,就从本地方法栈中分配一部分给本地方法。本地方法就是naitve修饰的方法(底层是C++)
在这里插入图片描述

程序计数器

某行程序在方法区中的内存地址
在这里插入图片描述

jvm_21">为什么jvm要设计程序计数器?

在这里插入图片描述
比如上面的程序,如果是多线程情况下,A线程执行到第4行的时候,被其他线程抢占资源,其他线程执行,其他线程完毕,A线程再回头执行,如果没有程序计数器,它就不知道它之前执行到第几行,就得重新执行,有了程序计数器,A线程一看,我之前执行到第4行,现在就从第4行开始再执行。

如果栈中存放的是变量是对象也就是引用类型的变量,那栈中存放的就是指向对象的指针,对象就存放在堆中,所有线程共享
在这里插入图片描述

方法区

存放常量+静态变量+类信息

方法区中存放的静态变量是引用类型的,那么方法区中存的即使静态引用变量的指针,对象还是存放到堆中。

在这里插入图片描述

JVM优化-堆详解

老年代占比2/3,年轻代占1/3。年轻代:8:1:1,年轻代又分为伊甸园区、s0、s1
在这里插入图片描述

JVM底层垃圾回收机制

在这里插入图片描述
新创建的对象都在新生代的伊甸园区,当伊甸园区满了后,字节码执行引擎就会开启垃圾收集线程,开始进行垃圾回收
常见的垃圾回收算法:

  • 引用计数法(已经淘汰了)
    在这里插入图片描述
  • 根可达性分析算法
    在这里插入图片描述垃圾收集线程根据根可达算法,找到垃圾后把非垃圾转移到survivor(幸存者)区域,而垃圾就被直接干掉了
    survivor区域的对象会在s0和s1之间反复挪动,一个minor gc挪动一次,当挪动15次也就是minor gc15次后,也叫分代年龄15次,还没有被干掉,就移动到老年代。
    在这里插入图片描述

jvm_45">jvm调优工具

jvisualvm.exe

调出jdk自带jvisualvm.exe工具进行查看
在这里插入图片描述

  • 测试代码
public class HeapTest {
    byte [] a=new byte[1024*100]; //100KB

    public static void main(String[] args) throws InterruptedException {
        ArrayList<HeapTest> heapTests=new ArrayList<>();
        while (true){
            heapTests.add(new HeapTest());
            TimeUnit.SECONDS.sleep(2);
        }
    }
}

执行本地方法就可以监视到
在这里插入图片描述

Arthas工具使用

在这里插入图片描述


http://www.niftyadmin.cn/n/5556509.html

相关文章

QQ频道导航退出

若该文为原创文章&#xff0c;转载请注明原文出处 本文章博客地址&#xff1a;https://hpzwl.blog.csdn.net/article/details/140413538 长沙红胖子Qt&#xff08;长沙创微智科&#xff09;博文大全&#xff1a;开发技术集合&#xff08;包含Qt实用技术、树莓派、三维、OpenCV…

Netty ChannelPipeline/ChannelHandler

在Netty中&#xff0c;ChannelPipeline和ChannelHandler是处理网络事件的核心组件。ChannelPipeline是一个处理器链&#xff0c;它负责处理和拦截入站和出站事件&#xff0c;而ChannelHandler则是这个链中的处理器。 ChannelPipeline ChannelPipeline是一个Netty特有的概念&a…

Mysql:解决CPU飙升至100%问题的系统诊断与优化策略

在服务器运维过程中&#xff0c;CPU使用率飙升到100%是一个常见且棘手的问题。这不仅会严重影响服务器的性能&#xff0c;还可能导致服务中断。当遇到这类情况时&#xff0c;首要任务是快速定位问题源头并采取相应措施。以下是一个基于操作系统命令和MySQL数据库优化的详细解决…

【全面介绍Pip换源】

&#x1f3a5;博主&#xff1a;程序员不想YY啊 &#x1f4ab;CSDN优质创作者&#xff0c;CSDN实力新星&#xff0c;CSDN博客专家 &#x1f917;点赞&#x1f388;收藏⭐再看&#x1f4ab;养成习惯 ✨希望本文对您有所裨益&#xff0c;如有不足之处&#xff0c;欢迎在评论区提出…

Go语言--广播式并发聊天服务器

实现功能 每个客户端上线&#xff0c;服务端可以向其他客户端广播上线信息&#xff1b;发送的消息可以广播给其他在线的客户支持改名支持客户端主动退出支持通过who查找当前在线的用户超时退出 流程 变量 用户结构体 保存用户的管道&#xff0c;用户名以及网络地址信息 typ…

问题复盘|Spring Boot 项目启动时避免空指针异常的解决方案

文章目录 问题描述解决方案1. 使用 Autowired 注入2. 延迟初始化3. 使用 PostConstruct 注解4. 确保 ApplicationContextHolder 初始化正确 结论 Hello大家好&#xff0c;我是阿月&#xff0c;坚持学习&#xff0c;老年痴呆追不上我。 在Spring Boot项目中&#xff0c;空指针异…

【通信协议-RTCM】MSM语句(1) - 多信号GNSS观测数据消息格式

注释&#xff1a; RTCM响应消息1020为GLONASS星历信息&#xff0c;暂不介绍&#xff0c;前公司暂未研发RTCM消息类型版本的DR/RTK模块&#xff0c;DR/RTK模块仅NMEA消息类型使用 注释&#xff1a; 公司使用的多信号语句类型为MSM4&MSM7&#xff0c;也应该是运用最广泛的语句…

安全加固:Eureka服务实例安全组配置全攻略

安全加固&#xff1a;Eureka服务实例安全组配置全攻略 在微服务架构中&#xff0c;服务的安全性是保障系统稳定性和数据完整性的关键。Eureka作为Netflix开源的服务发现框架&#xff0c;不仅提供服务注册与发现功能&#xff0c;还可以通过配置服务实例安全组来增强安全性。本文…