
JVM学习
视频观看地址b站: 尚硅谷JVM
haitaoss
这个作者很懒,什么都没留下…
展开
-
17-垃圾回收器
GC分类与性能指标垃圾回收器概述垃圾收集器没有在规范中进行过多的规定,可以由不同的厂商、不同版本的JVM来实现。由于JDK的版本处于高速迭代过程中,因此Java发展至今已经衍生了众多的GC版本。从不同角度分析垃圾收集器,可以将GC分为不同的类型。垃圾回收器分类按线程数分按线程数分,可以分为串行垃圾回收器和并行垃圾回收器。串行回收指的是在同一时间段内只允许有一个CPU用于执行垃圾回收操作,此时工作线程被暂停,直至垃圾收集工作结束。在诸如单CPU处理器或者较小的应用内存等硬件平台不是特原创 2020-09-29 10:20:38 · 402 阅读 · 0 评论 -
16-垃圾回收相关概念
System.gc() 的理解在默认情况下,通过System. gc()或者Runtime.getRuntime().gc()的调用,会显式触发Full GC,同时对老年代和新生代进行回收,尝试释放被丢弃对象占用的内存。然而System.gc()调用附带一个免责声明,无法保证对垃圾收集器的调用。JVM实现者可以通过System.gc()调用来决定JVM的GC行为。而一般情况下,垃圾回收应该是自动进行的,无须手动触发,否则就太过于麻烦了。在一些特殊情况下,如我们正在编写一个性能基准,我们可以在运行之间调原创 2020-09-28 22:23:40 · 242 阅读 · 0 评论 -
15-垃圾回收相关算法
垃圾标记阶段:引用计数算法垃圾标记阶段:对象存活判断在堆里存放着几乎所有的Java对象实例,在GC执行垃圾回收之前,首先需要区分出内存中哪些是存活对象,哪些是已经死亡的对象。只有被标记为己经死亡的对象,GC才会在执行垃圾回收时,释放掉其所占用的内存空间,因此这个过程我们可以称为垃圾标记阶段。那么在JVM中究竟是如何标记一个死亡对象呢?简单来说,当一个对象已经不再被任何的存活对象继续引用时,就可以宣判为已经死亡。判断对象存活一般有两种方式:引用计数算法和可达性分析算法。引用计数算法概述引用计原创 2020-09-28 22:22:59 · 160 阅读 · 0 评论 -
14-垃圾回收概述
什么是垃圾常见问题垃圾收集,不是Java语言的伴生产物。早在1960年,第一门开始使用内存动态分配和垃圾收集技术的Lisp语言诞生。关于垃圾收集有三个经典问题:哪些内存需要回收?什么时候回收?如何回收?垃圾收集机制是Java的招牌能力,极大地提高了开发效率。如今,垃圾收集几乎成为现代语言的标配,即使经过如此长时间的发展,Java的垃圾收集机制仍然在不断的演进中,不同大小的设备、不同特征的应用场景,对垃圾收集提出了新的挑战,这当然也是面试的热点。什么是垃圾?什么是垃圾(原创 2020-09-28 22:22:05 · 160 阅读 · 0 评论 -
13-StringTable
String的基本特性String: 字符串,使用一对""引起来表示。String s1 = “atguigu”; // 字面量的定义方式String s2 = new String(“hello”);String 声明为final的,不可被继承String 实现了Serializable 接口:表示字符串是支持序列化的。实现了Comparable 接口:表示String可比较大小String在jdk8 及以前内部定义了final char[] value 用于存储字符串数原创 2020-09-28 22:21:21 · 232 阅读 · 0 评论 -
12-执行引擎
执行引擎概述执行引擎是Java虚拟机核心的组成部分之一。“虚拟机”是一个相对于“物理机”的概念,这两种机器都有代码执行能力,其区别是物理机的执行引擎是直接建立在处理器、缓存、指令集和操作系统层面,上的,而虚拟机的执行引擎则是由软件自行实现的,因此可以不受物理条件制约地定制指令集与执行引擎的结构体系,能够执行那些不被硬件直接支持的指令集格式。JVM的主要任务是负责装载字节码到其内部,但字节码并不能够直接运行在操作系统之上,因为字节码指令并非等价于本地机器指令,它内部包含的仅仅只是一些能够被JVM所原创 2020-09-28 22:19:50 · 145 阅读 · 0 评论 -
11-直接内存
直接内存概述不是虚拟机运行时数据区的一部分,也不是《Java虚拟机规范》中定义的内存区域。直接内存是在Java堆外的、直接向系统申请的内存区间。来源于NIO,通过存在堆中的DirectByteBuffer操作Native内存通常,访问直接内存的速度会优于Java堆。即读写性能高。因此出于性能考虑,读写频繁的场合可能会考虑使用直接内存。Java的NIO库允许Java程序使用直接内存,用于数据缓冲区也可能导致OutOfMemoryError异常由于直接内存在Java堆外,因此它的原创 2020-09-28 22:19:02 · 113 阅读 · 0 评论 -
10-对象的实例化内存布局与访问定位
对象的实例化前面所述是从字节码角度看待对象的创建过程,现在从执行步骤的角度来分析:判断对象对应的类是否加载、链接、初始化虚拟机遇到一条new指令,首先去检查这个指令的参数能否在Metaspace的常量池中定位到一个类的符号引用,并且检查这个符号引用代表的类是否已经被加载、解析和初始化。( 即判断类元信息是否存在)。如果没有,那么在双亲委派模式下,使用当前类加载器以ClassLoader+包名+类名为Key进行查找对应的.class文件。如果没有找到文件,则ClassNotFoundExcep原创 2020-09-26 16:58:03 · 139 阅读 · 0 评论 -
09-方法区
栈、堆、方法区的交互关系方法区的理解方法区在哪里《Java虚拟机规范》中明确说明: "尽管所有的方法区在逻辑上是属于堆的一部分, 但一些简单的实现可能不会选择去进行垃圾收集或者进行压缩。”但对于HotSpotJVM而言,方法区还有一个别名叫做Non-Heap(非堆),目的就是要和堆分开。所以,方法区看作是一块独立于Java堆的内存空间。https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-2.html#jvms-2.5.4方原创 2020-09-26 16:57:10 · 222 阅读 · 0 评论 -
08-堆
回顾学习jvm肯定是为了性能的优化,我们可以使用可视化工具查看项目的资源使用情况。根据资源耗费情况我们合理的规划内存的分配。如何合理的规划内存的分配这就需要学习jvm中内存的结构。要想对内存结构有更好的理解,需要知道class文件的加载过程和class文件的内容以及如何执行class文件。栈管运行,堆管存储堆的核心概述堆核心概述:概述heap一个JVM实例只存在一个堆内存,堆也是Java内存管理的核心区域。Java堆区在JVM启动的时候即被创建,其空间大小也就确定了。是JVM 管理的最大原创 2020-09-26 16:55:00 · 284 阅读 · 0 评论 -
07-本地方法栈
本地方法栈Java虚拟机栈用于管理Java方法的调用,而本地方法栈用于管理本地方法的调用。本地方法栈,也是线程私有的。允许被实现成固定或者是可动态扩展的内存大小。(在内存溢出方面是相同的)如果线程请求分配的栈容量超过本地方法栈允许的最大容量,Java虚拟机将会抛出一个StackOverflowError 异常。如果本地方法栈可以动态扩展,并且在尝试扩展的时候无法申请到足够的内存,或者在创建新的线程时没有足够的内存去创建对应的本地方法栈,那么Java虚拟机将会抛出一个OutOfMemoryErr原创 2020-09-26 16:53:54 · 102 阅读 · 0 评论 -
06-本地方法接口
什么是本地方法简单地讲,一个Native Method就是一个Java调用非Java代码的接口。一个Native Method是这样 一个Java方法:该方法的实现由非Java语言实现,比如C。这个特征并非Java所特有,很多其它的编程语言都有这一机制,比如在C++中,你可以用extern “C” 告知C+ +编译器去调用一个C的函数。"A native method is a Java method whose implementation isprovided by non-java code.原创 2020-09-26 16:53:11 · 103 阅读 · 0 评论 -
05-虚拟机栈
虚拟机栈概述背景由于跨平台性的设计,Java的指令都是根据栈来设计的。不同平台CPU架构不同,所以不能设计为基于寄存器的。优点是跨平台,指令集小,编译器容易实现,缺点是性能下降,实现同样的功能需要更多的指令。内存中的栈与堆栈是运行时的单位,而堆是存储的单位。即:栈解决程序的运行问题,即程序如何执行,或者说如何处理数据。堆解决的是数据存储的问题,即数据怎么放、放在哪儿。虚拟机栈基本内容Java虚拟机栈是什么?Java虚拟机栈(Java Virtual Machine Sta原创 2020-09-26 16:51:50 · 157 阅读 · 0 评论 -
04-程序计数器
程序计数器(PC寄存器)PC Register介绍JVM中的程序计数寄存器( Program Counter Register) 中,Register 的命名源于CPU的寄存器,寄存器存储指令相关的现场信息。CPU只有把数据装载到寄存器才能够运行。这里,并非是广义上所指的物理寄存器,或许将其翻译为PC计数器(或指令计数器)会更加贴切(也称为程序钩子),并且也不容易引起一些不必要的误会。JVM中的PC寄存器是对物理PC寄存器的一种抽象模拟。它是一块很小的内存空间,几乎可以忽略不记。也是运行速原创 2020-09-26 16:50:24 · 107 阅读 · 0 评论 -
03-运行时数据区概述及线程
概述内存是非常重要的系统资源,是硬盘和CPU的中间仓库及桥梁,承载着操作系统和应用程序的实时运行。JVM内存布局规定了Java在运行过程中内存申请、分配、管理的策略,保证了JVM的高效稳定运行。不同的JVM对于内存的划分方式和管理机制存在着部分差异。结合JVM虚拟机规范,来探讨一下经典的JVM内存布局。运行时数据区的详细图(来源:阿里手册 )线程线程的概念线程是一个程序里的运行单元。JVM允许一个应用有多个线程并行的执行。在HotspotJVM里,每个线程都与操作系统的本地线程原创 2020-09-26 16:49:03 · 87 阅读 · 0 评论 -
02-类加载子系统
内存结构概述内存图类加载器与类的加载过程类加载子系统作用类加载器子系统负责从文件系统或者网络中加载Class文件,class文件在文件开头有特定的文件标识。ClassLoader只负责class文件的加载,至于它是否可以运行,则由Execution Engine决定。加载的类信息存放于一块称为方法区的内存空间。除了类的信息外,方法区中还会存放运行时常量池信息,可能还包括字符串字面量和数字常量(这部分常量信息是Class文件中常量池部分的内存映射)类加载ClassLoader角色原创 2020-09-26 16:46:55 · 156 阅读 · 0 评论 -
01-JVM与Java体系结构
Java发展的重大事件1990年,在Sun计算机公司中,由Patrick Naughton、MikeSheridan及James Gosling 领导的小组Green Team, 开发出的新的程序语言,命名为0ak,后期命名为Java.1995年,Sun正式发布Java和HotJava产品,Java 首次公开亮相。1996年1月23日Sun Microsystems发布了JDK 1.0。1998年,JDK 1.2版本发布。同时,Sun发布了JSP/Servlet、 EJB规范,以及将Java分成了原创 2020-09-26 16:45:31 · 1431 阅读 · 0 评论