1-JVM基础
1-JVM基础
java源码文件,通过javac 转换成class文件。
找到.java文件
词法分析器
tokens流
语法分析器
语义分析器
字节码生成器
转成.class文件
装载
根据全限定路径名寻找class文件,转换成二进制流。通过ClassLoder.load(String name)(类装载器,name:全限定路径名)不同路径下的类,设置不同路径的类装载器。
Bootstrap ClassLoader(根装载器由C语言编写):加载
$JAVA_HOME中的jar/lib/rt.jar里所有的class或Xbootclassoath选项指定的jar包Extension ClassLoader:加载Java平台中扩展功能的一些jar包,包括
$JAVA_HOME中jar/lib/*.jar或-Djava.ext.dirs指定目录下的jar包App ClassLoader:加载classpath中指定的jar包及
Djava.class.path所指定目录下的类和jar包Custom ClassLoader(自定义装载器改变装载原则,如Tomcat打破双亲委派机制):通过
java.lang.ClassLoader的子类自定义加载class,属于应用程序根据自身需要自定义的ClassLoader,如Tomcat、JBoss都会根据j2ee规范自行实现ClassLoader
需要把类文件静态存储结构里面对应的内容存储到JVM里面(方法区的运行时数据结构)
代码里一段方法不宜过长(阿里规范中提到一段方法不应超过80行)。方法存到JVM里的栈帧。内容一旦超过一定行数或者过长时,JVM就会从编译性改变为解释性,从而导致性能下降。
java.lang.Class对象存储到堆内存
链接
验证
保证被加载的正确性。验证class文件中的cafe babe。注:class文件中,已cafe babe为开头的是java文件。
准备
为类的静态变量分配内存。如:
private static int a = 3;//为a分配内存,并且将a初始化默认值,默认值:a=0解析
将类中的符号引用转换为直接引用。静态的转换。
符号引用:就是class文件中的内容,符合JVM规范的内容,JVM认识的语言。
直接引用:在Java进程中能够代表真实含义的。JVM更底层,计算机能够认识的语言,并且操作的。比方说为某个静态变量分配了真实的内存。
初始化
对类的静态变量,进行正真的初始化。就是将上一步中的准备过程中的
private static int a = 3;//为a分配内存,并且将a初始化默认值,默认值:a=0。将3正真的赋值 a = 3。
JVM运行时划分的区域:
程序最小单位是进程(数据不安全进程内的数据会被该进程内所有的线程共享),进程包含多个线程。
线程是进程最小的执行单位。
栈:只要符合栈结构,都遵循先进后出的原则
方法区 Method Area(进程)、非堆:类信息【类的创建时间、作者、元数据(数据描述信息)】、常量【final】、静态变量【static】、即时编译器编译后的代码。里面存储的是一些。类类型加载的东西(也就是反射中的.class之后的Class),用于存储已经被虚拟机加载的类的信息、常量、静态变量等。与堆一样,是被线程共享的内存区域,要注意线程安全问题。方法区逻辑上属于堆的一部分。如果存储数据大小超过了比方说1个G就会报OutOfMemoryError(OOM)异常。
堆 Heap(进程):代表某个类的java.lang.Class对象。存储对象、String、数组。如果存储数据大小超过了比方说1个G就会报OutOfMemoryError(OOM)异常。
Java虚拟机栈(线程):一个线程当中会有一个私有Java虚拟机栈。生命周期是与线程绑定在一起。存储Java方法。
在Java方法中如何去调用C语言的方法,通过动态链接去调用完成。
本地方法栈(线程):存储C语言方法。
栈帧(Java虚拟机栈、本地方法栈)Frame:代表是方法的执行。一个栈帧被创建就表示一个方法被执行,方法压栈先进后出。
//伪代码1
a(){
b();
}
b(){
c();
}
c(){ }
//先进行压栈
//先往Java虚拟机中压栈存入a(),之后是b(),在之后是c()。
//之后是出栈
//在c()方法执行完之后先出,b()执行完再出,最后是a()执行完再出。
//先进后出的概念。 //伪代码2
a(){
a();
}
//如果递归一直调用自己,超出栈的长度或深度,就会报StackOverflowError(栈溢出)。同理如果一个方法内部的调用链非常长或深的话也一样会报StackOverflowError(栈溢出)。
局部变量表:存储方法中的局部变量
操作数栈:栈结构,用来描述运算过程当中数据暂时的存储位置
//伪代码.java文件
public static int calc(int op1,int op2){
op1 = 3;
int result = op1 + op2;
return result;
}
//.java文件的.class文件翻译的JVM字节码。
public static int calc(int op1,int op2);
Code:
0:iconst_3 // 将3放到操作数栈中
//局部变量下标:如果是类级别方法【static修饰的方法】下标是从0开始;如果是实例方法下标从1开始,0标识的是这个实例,保留给当前对象的引用this。
1:istore_0 //将操作数占中的3赋值给局部变量表中的局部变量
2:iload_0 //将局部变量0值放到操作数栈中
3:iload_1 //
4:iadd
5:istore_2
6:iload_2
7:ireturn
动态链接:符号引用转换为直接引用**。动态的转换。比方说:一个方法调用某个接口或抽象类,这时是不知道这个方法内部具体实现的,只有等到程序运行时才能知道具体是调用了哪个子类或实现类的方法。
正常或异常方法的返回:
程序计数器(线程):是一块较小的内存空间,它可以看做是当前线程所执行的字节码的行号指示器。在虚拟机的概念模型里(仅是概念模型,各种虚拟机可能会通过一些更高效的方式去实现),字节码解释器工作时就是通过改变这个计数器的值来选取下一条需要执行的字节码指令,分支、循环、跳转、异常处理、线程恢复等基础功能都需要依赖这个计数器来完成。
JAVA 对象内存布局
对象头:
Mark Word:一系列的标记为(哈希码,分代年龄,锁状态标志等)64位系统:8字节
Class Pointer:指向对象对应的类元数据的内存地址 64位系统:8字节
Length数组对象特有:数组长度 4字节
实例数据:
包含了对象的所有成员变量,大小由各个变量类型决定
boolean和byte:1字节
short和char:2字节
int和float:4字节
long和double:8字节
reference:8字节(64位系统)
对齐填充:
为了保证对象的大小为8字节的整数倍,会进行填充字节
赵小胖个人博客
1-JVM基础的更多相关文章
- JVM 基础知识
JVM 基础知识(GC) 2013-12-10 00:16 3190人阅读 评论(1) 收藏 举报 分类: Java(49) 目录(?)[+] 几年前写过一篇关于JVM调优的文章,前段时间拿出来看了看 ...
- java 笔记(1)-—— JVM基础,内存数据,内存释放,垃圾回收,即时编译技术JIT,高精度类型
1.java中5个存放数据的地方: (1).寄存器(Registers):位于CPU内部,是速度最快的存储区,但是数量和容量有限.在java中不能直接操作寄存器. (2).栈(Stack):栈位于通用 ...
- JVM基础:深入学习JVM堆与JVM栈
转自:http://developer.51cto.com/art/201009/227812.htm JVM栈解决程序的运行问题,即程序如何执行,或者说如何处理数据;JVM堆解决的是数据存储的问题, ...
- JVM基础知识(1)-JVM内存区域与内存溢出
JVM基础知识(1)-JVM内存区域与内存溢出 0. 目录 什么是JVM 运行时数据区域 HotSpot虚拟机对象探秘 OutOfMemoryError异常 1. 什么是JVM 1.1. 什么是JVM ...
- Jvm基础(2)-Java内存模型
Jvm基础(2)-Java内存模型 主内存和工作内存 Java内存模型包括主内存和工作内存两个部分:主内存用来存储线程之间的共享变量:而工作内存中存储每个线程的相关变量. 如下图所示: 需要注意的是: ...
- 剑指Offer——知识点储备-JVM基础
剑指Offer--知识点储备-JVM基础 1.java内存与内存溢出 1.1 JVM分为哪些区,每一个区干嘛的?(见java虚拟机38页) (1)程序计数器(线程私有) 当前线程执行字节码的信号指示器 ...
- JVM基础系列第15讲:JDK性能监控命令
查看虚拟机进程:jps 命令 jps 命令可以列出所有的 Java 进程.如果 jps 不加任何参数,可以列出 Java 程序的进程 ID 以及 Main 函数短名称,如下所示. $ jps 6540 ...
- JVM基础系列第14讲:JVM参数之GC日志配置
说到 Java 虚拟机,不得不提的就是 Java 虚拟机的 GC(Garbage Collection)日志.而对于 GC 日志,我们不仅要学会看懂,而且要学会如何设置对应的 GC 日志参数.今天就让 ...
- JVM基础系列第13讲:JVM参数之追踪类信息
我们都知道 JVM 在启动的时候会去加载类信息,那么我们怎么得知他加载了哪些类,又卸载了哪些类呢?我们这一节就来介绍四个 JVM 参数,使用它们我们就可以清晰地知道 JVM 的类加载信息. 为了方便演 ...
- JVM基础系列第11讲:JVM参数之堆栈空间配置
JVM 中最重要的一部分就是堆空间了,基本上大多数的线上 JVM 问题都是因为堆空间造成的 OutOfMemoryError.因此掌握 JVM 关于堆空间的参数配置对于排查线上问题非常重要. tips ...
随机推荐
- vim-1-window,buffer and tab
Summary:A buffer is the in-memory text of a file. A window is a viewport on a buffer. A tab page is ...
- postgre安装和使用(R&Python)
安装postgre http://helianthus-code.lofter.com/post/1dfe03e0_1c68233aa 这里选C更好 这里口令密码输入就是黑的 我装的时候反复报错,查了 ...
- FME中按照ID值过滤块参照中的多个要素
- Java并发基础05. 传统线程同步通信技术
先看一个问题: 有两个线程,子线程先执行10次,然后主线程执行5次,然后再切换到子线程执行10,再主线程执行5次--如此往返执行50次. 看完这个问题,很明显要用到线程间的通信了, 先分析一下思路:首 ...
- Python 程序慢的像蜗牛,我该怎么办?
1. “一猿小讲”的风格就是多元化,偶尔会真情吐露一下程序猿的内心:偶尔也结合自己的经历畅聊一些经验杂谈:其中也不乏幽默风趣的技术故事.分享是件快乐的事情,工作之余,有时间我就尽力多码字,多推几篇文章 ...
- CAP定理和BASE理论
CAP定理和BASE理论 标签(空格分隔): 操作系统 CAP定理 CAP定理: 一个分布式系统最多只能满足一致性 (Consistency), 可用性(Availability)和分区容错性(Par ...
- 基于华为云IoT Studio自助生成10万行代码的奥秘
华为IoT小助手们搬好板凳.备好笔记本.听了HDC.Cloud的几场华为云技术架构师的直播讲课,感觉获益匪浅却又似懂非懂,直后悔自己没有好好打下基础.为了避免再次出现这样的情况,小助手偷偷跑去找了华为 ...
- centos默认终端bash美化、颜色设置
centos默认终端bash是一个很简单的界面,又无法通过像zsh一样直接安装主题和代码高亮插件,但是我们可以在bashrc的配置文件中通过代码实现一部分功能: 1.代码介绍: 这里推荐一篇大佬的文章 ...
- 单周期CPU
一个时钟周期执行一条指令的过程理解(单周期CPU): https://blog.csdn.net/a201577F0546/article/details/84726912 单周期CPU指的是一条指令 ...
- Linux服务器架设篇,DNS服务器(二),cache-only DNS服务器的搭建
一.理论基础 什么是cache-only服务器?即不具备自己正反解Zone的能力,仅进行缓存或转发的DNS服务器.其实它也称不上是DNS服务器.但是也是一个必备的知识点. 这种服务器只有缓存搜索结果的 ...