• jvm笔记


    好处:

    跨平台

    内存管理机制,垃圾回收功能

    数组下标越界检查

    多态

    名词解释: 

    jvm java虚拟机,是java程序的运行环境

    jre jvm+基础类库

    jdk jre+编译工具

    javase jdk+ide工具

    javaee javase+应用服务器

    jvm的内存结构: 

    程序计数器:

            java源代码-->jvm指令--解释器-->机器码-->cpu

            寄存器,记住下一条jvm指令的地址

            程序计数器是线程私有的,而且没有内存溢出

    虚拟机栈:

            每个线程运行所需要的内存,由栈帧组成,一个栈帧就是一次方法的调用,栈帧是每个

            方法运行时需要的内存,每个线程只能有一个活动的栈帧,就是正在执行的那个方法

    本地方法栈:

            一些方法用native修饰表明方法的实现是用C语言或者其他语言实现的,不是用java实现

            的。

    堆:

            通过new关键字创建的对象都会使用堆内存,堆是线程共享的,有垃圾回收机制

            字符串常量池。自java8开始,StringTable在堆里,

    方法区:

            是堆的一部分,所以方法区是内存共享的。java8后取而代之的是元空间,运行时常量池

            和静态常量池存放在元空间里,占用操作系统的内存,字符串常量池依然存放在堆里。

            字符串常量池用hashTable结构,

    栈问题:

    1、垃圾回收机制是否会回收栈内存?

            不会,垃圾回收是回收堆里面的内存对象。栈内存不需要回收,因为方法结束后栈内存

            就自己释放掉了。

    2、栈内存分配越大越好吗?

            不是,栈内存越大会导致线程数越少

    3、方法内的局部变量是否线程安全?

            不一定,如果变量没有逃离方法的作用范围,那就是线程安全的,反之就不是线程安全

            的(方法参数,方法返回值,局部变量引用了对象),。栈是线程私有的,static变量是

            在堆中的就不是线程安全的了。

    栈内存溢出的原因:

    方法栈帧过多(方法递归)

    方法栈帧过大(方法的局部变量太多)

    新生代:

    老年代:

    永久代:使用jvm的堆的内存。java8之后,取消了整个永久代区域,取而代之的是元空间。

    元空间:使用操作系统的内存,运行时常量池静态常量池

    直接内存:操作系统的内存

    垃圾回收:

    bilibili.com/video/BV1yE411Z7AP P52

  • 相关阅读:
    【小程序】解决浮点数精度损失问题
    C++特殊定制:揭秘cpo与tag_invoke!
    深入 Hyperf:HTTP 服务启动时发生了什么?
    ubuntu22.04编译PBRT-v4
    使用Python实现几种底层技术的数据结构
    2022 年杭电多校第七场补题记录
    【计算机网络】第一章 概述
    1. JavaScript有哪些数据类型, 它们的区别?
    维纳滤波器小结
    模拟实现简单的通讯录
  • 原文地址:https://blog.csdn.net/m0_58961367/article/details/133410845