JVM上篇:内存与垃圾回收篇
文章平均质量分 95
JVM上篇:内存与垃圾回收篇
Aur_ora
这个作者很懒,什么都没留下…
展开
-
JVM第十二章-垃圾回收器
1. GC分类与性能指标垃圾收集器没有在规范中进行过多的规定,可以由不同的厂商、不同版本的JVM来实现。由于JDK的版本处于高速迭代过程中,因此Java发展至今已经衍生了众多的GC版本。从不同角度分析垃圾收集器,可以将GC分为不同的类型。Java不同版本新特性语法层面:Lambda表达式、switch、自动拆箱装箱、enum、泛型API层面:Stream API、新的日期时间、Optional、String、集合框架底层优化:JVM优化、GC的变化、元空间、静态域、字符串常量原创 2021-06-27 12:38:17 · 132 阅读 · 0 评论 -
JVM第十一章-垃圾回收相关概念
1. System.gc() 的理解在默认情况下,通过System.gc()者Runtime.getRuntime().gc() 的调用,会显式触发Full GC,同时对老年代和新生代进行回收,尝试释放被丢弃对象占用的内存。然而System.gc()调用附带一个免责声明,无法保证对垃圾收集器的调用(不能确保立即生效)JVM实现者可以通过System.gc() 调用来决定JVM的GC行为。而一般情况下,垃圾回收应该是自动进行的,**无须手动触发,否则就太过于麻烦了。**在一些特殊情况下,如我原创 2021-06-27 09:18:38 · 145 阅读 · 0 评论 -
JVM第十章-垃圾回收概述和相关算法
垃圾回收概述Java 和 C++语言的区别,就在于垃圾收集技术和内存动态分配上,C++语言没有垃圾收集技术,需要程序员手动的收集。垃圾收集,不是Java语言的伴生产物。早在1960年,第一门开始使用内存动态分配和垃圾收集技术的Lisp语言诞生。关于垃圾收集有三个经典问题:哪些内存需要回收?什么时候回收?如何回收?垃圾收集机制是Java的招牌能力,极大地提高了开发效率。如今,垃圾收集几乎成为现代语言的标配,即使经过如此长时间的发展,Java的垃圾收集机制仍然在不断的..原创 2021-06-27 09:17:57 · 141 阅读 · 0 评论 -
JVM第九章-StringTable
1. String的基本特性String:字符串,使用一对 “” 引起来表示使用“”的会被放到字符串常量池,new的不会放到字符串常量池String s1 = "atguigu" ; // 字面量的定义方式String s2 = new String("hello"); // new 对象的方式String被声明为final的,不可被继承String实现了Serializable接口:表示字符串是支持序列化的。实现了Comparable接口:表示String可以原创 2021-06-27 09:17:14 · 189 阅读 · 0 评论 -
JVM第八章-执行引擎
1. 执行引擎概述1.1 概述执行引擎是Java虚拟机核心的组成部分之一。“虚拟机”是一个相对于“物理机”的概念,这两种机器都有代码执行能力,其区别是物理机的执行引擎是直接建立在处理器、缓存、指令集和操作系统层面上的,而虚拟机的执行引擎则是由软件自行实现的,因此可以不受物理条件制约地定制指令集与执行引擎的结构体系,能够执行那些不被硬件直接支持的指令集格式。JVM的主要任务是负责装载字节码到其内部,但字节码并不能够直接运行在操作系统之上,因为字节码指令并非等价于本地机器指令,它内部包含的仅仅只是一原创 2021-06-27 09:16:29 · 140 阅读 · 0 评论 -
JVM第七章-对象的实例化内存布局与访问定位
1. 对象的实例化大厂面试题美团:对象在JVM中是怎么存储的?对象头信息里面有哪些东西?蚂蚁金服:二面:java对象头里有什么1.1 对象创建的方式new:最常见的方式、单例类中调用getInstance的静态类方法,XXXFactory的静态方法Class的newInstance方法:在JDK9里面被标记为过时的方法,因为只能调用空参构造器,并且权限必须为 publicConstructor的newInstance(Xxxx):反射的方式,可以调用空参的,或者带参的构造器,权限原创 2021-06-27 09:15:40 · 96 阅读 · 0 评论 -
JVM第六章-方法区
1. 栈、堆、方法区的交互关系从线程共享与否的角度来看ThreadLocal:如何保证多个线程在并发环境下的安全性?典型场景就是数据库连接管理,以及会话管理。栈、堆、方法区的交互关系下面涉及了对象的访问定位Person 类的 .class 信息存放在方法区中person 变量存放在 Java 栈的局部变量表中真正的 person 对象存放在 Java 堆中在 person 对象中,有个指针指向方法区中的 person 类型数据,表明这个 person 对象是用方法区中的 Person 类原创 2021-06-27 09:13:48 · 94 阅读 · 0 评论 -
JVM第五章-堆
1. 堆的核心概述1.1 堆与进程一个java程序对应一个进程一个进程对应一个jvm实例一个jvm实例中只有一个运行时数据区一个运行时数据区只有一个方法区和堆一个进程中的多个线程需要共享同一个方法区,堆空间每一个线程拥有独立的一套程序计数器,虚拟机栈,本地方法栈堆针对一个JVM进程来说是唯一的。也就是一个进程只有一个JVM实例,一个JVM实例中就有一个运行时数据区,一个运行时数据区只有一个堆和一个方法区。但是进程包含多个线程,他们是共享同一堆空间的。一个JVM实例只存在原创 2021-06-23 17:28:44 · 125 阅读 · 0 评论 -
JVM第四章-虚拟机栈
1. 简介1.1 虚拟机栈的出现背景由于跨平台性的设计,Java的指令都是根据栈来设计的。不同平台CPU架构不同,所以不能设计为基于寄存器的【如果设计成基于寄存器的,耦合度高,性能会有所提升,因为可以对具体的CPU架构进行优化,但是跨平台性大大降低】。优点是跨平台,指令集小,编译器容易实现,缺点是性能下降,实现同样的功能需要更多的指令。1.2 内存中的堆与栈首先栈是运行时的单位,而堆是存储的单位。栈解决程序的运行问题,即程序如何执行,或者说如何处理数据。堆解决的是数据存储的问题,即数据怎原创 2021-06-23 15:13:34 · 106 阅读 · 0 评论 -
JVM第三章-运行时数据区
1. 运行时数据区概述及线程1.1 前言本节主要讲的是运行时数据区,也就是下图这部分,它是在类加载完成后的阶段当我们通过前面的:类的加载 --> 验证 --> 准备 --> 解析 --> 初始化,这几个阶段完成后,就会用到执行引擎对我们的类进行使用,同时执行引擎将会使用到我们运行时数据区类比一下也就是大厨做饭,我们把大厨后面的东西(切好的菜,刀,调料),比作是运行时数据区。而厨师可以类比于执行引擎,将通过准备的东西进行制作成精美的菜品。1.2 运行时数据区结构1.2原创 2021-06-23 15:12:23 · 98 阅读 · 0 评论 -
JVM第二章-类加载子系统
1. 内存结构概述1.1 简图1.2 详细图英文版中文版注意:方法区只有HotSpot虚拟机有,J9,JRockit都没有如果自己想手写一个Java虚拟机的话,主要考虑哪些结构呢?类加载器执行引擎2. 类加载子系统2.1 功能类加载器子系统作用:类加载器子系统负责从文件系统或者网络中加载Class文件,class文件在文件开头有特定的文件标识。ClassLoader只负责class文件的加载,至于它是否可以运行,则由Execution Engine决定。加载原创 2021-06-23 15:09:59 · 115 阅读 · 0 评论