JVM笔记(二)JVM基本结构
JVM基本结构
一、运行时内存区域
java虚拟机所管理的内存将会包括以下几个运行时内存区域。
1.程序计数器
Program Counter Register:可以看作当前线程(线程私有)所执行的字节码行号指示器。
2.Java虚拟机栈
Java Virtual Machine Stacks:也是线程私有的,描述了Java方法执行的内存模型:每个方法在执行时都会创建一个栈帧用于存储---局部变量表、操作数栈、动态链接、方法出口等信息。每一个方法从调用到执行完毕的过程,都对应着一个栈帧在虚拟机栈中入栈到出栈的过程。
局部变量表:存放了方法内部编译期可知的各种基本数据类型,对象引用类型。
在虚拟机规范中,虚拟机栈规定了两种异常情况:
1)StackOverflowError:线程请求栈的深度大于虚拟机所允许的深度。
2)OutOfMemoryError:虚拟机动态时,无法申请到足够的内存。
3.本地方法栈
与虚拟机栈的方法栈作用相似,只是本地方法栈为虚拟机使用的Native方法服务。可抛出虚拟机栈相同的异常。
4.Java堆
Java Heap:被所有线程共享的一块内存区域,在虚拟机启动时创建。用于存放对象实例和数组。是Java垃圾收集器所管理的主要区域,因此也被称为“GC堆”。Java虚拟机规定,Java堆可以处于物理上不连续的内存空间中,只要逻辑上是连续的即可。
可以抛出OutOfMemory异常。
5.方法区
Method Area:线程共享区域,用于存放已经被虚拟机加载的类信息、常量、静态变量、即时编译后的代码等信息。虚拟机规范把方法区描述为堆的一个逻辑部分。
6.运行时常量池
Runtime Constant Pool:方法区的一部分,Class文件中的常量池(用于存放编译期生成的各种字面量和符号引用)中的内容,在类加载后进入方法区中的常量池存放(也可将运行期间新产生的常量放入池中)。
7.直接内存
在JDK 1.4中新加入了NIO(New Input/Output)类,引入了一种基于通道(Channel)与缓冲区(Buffer)的I/O方式,它可以使用Native函数库直接分配堆外内存,然后通过一个存储在Java堆中的DirectByteBuffer对象作为这块内存的引用进行操作。 这样能在一些场景中显著提高性能,因为避免了在Java堆和Native堆中来回复制数据。
二、JVM内存模型
public class VolatileStopThread extends Thread{
private volatile boolean stop=false;
public void stopIt(){
stop=true;
} @Override
public void run(){
int i=0;
while (!stop){
i++;
}
System.out.println("Stoped running");
}
} public class MainClass { public static void main(String[] args) {
//没有volatile -server运行无法停止
//虽然很多情况下volatile性能比锁好但不能代替锁
//因为volatile不是线程安全的
VolatileStopThread v=new VolatileStopThread();
v.start();
try {
Thread.sleep(1000);
v.stopIt();
Thread.sleep(1000);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
线程内有序意思是:在本线程内的变量什么的编译器是会考虑语义的。
JVM笔记(二)JVM基本结构的更多相关文章
- muduo学习笔记(二)Reactor关键结构
目录 muduo学习笔记(二)Reactor关键结构 Reactor简述 什么是Reactor Reactor模型的优缺点 poll简述 poll使用样例 muduo Reactor关键结构 Chan ...
- jvm系列(二):JVM内存结构
JVM内存结构 所有的Java开发人员可能会遇到这样的困惑?我该为堆内存设置多大空间呢?OutOfMemoryError的异常到底涉及到运行时数据的哪块区域?该怎么解决呢?其实如果你经常解决服务器性能 ...
- JVM笔记(二) 垃圾收集器(1)
垃圾收集器 主要通过阅读<深入了解Java虚拟机>(周志明 著)和网络资源汇集而成,为本人学习JVM的笔记.同时,本文理论基于JDK 1.7版本,暂不考虑 1.8和1.9 的新特性,但可能 ...
- jVM笔记4-对象的结构
1.对象的结构有: 1.Header(对象头),其组成主要有两部分: 1.自身运行时的数据(Mark Word),包括: 1.哈希值 2.GC分代年龄. 3.锁状态标志 4.线程所持有的锁 5.偏向线 ...
- C#学习笔记二:C#程序结构
从最简单的HelloWorld开始入手,这是一个最低限度的C#程序结构. C# Hello World 示例 一个C#程序主要由以下几部分组成: 命名空间声明 一个类 类方法 类属性 一个Main方法 ...
- Android Studio安卓学习笔记(二)Android项目结构
上一篇代码,我们学习了Android的功能以及如何用Android Studio开发第一个安卓程序.下面就要介绍Android项目结构.为日后学习打基础. 一:Android项目结构 打开MyFris ...
- JVM(二)Java虚拟机组成详解
导读:详细而深入的总结,是对知识"豁然开朗"之后的"刻骨铭心",想忘记都难. Java虚拟机(Java Virtual Machine)下文简称jvm,上一篇我 ...
- jvm系列(七):jvm调优-工具篇
16年的时候花了一些时间整理了一些关于jvm的介绍文章,到现在回顾起来还是一些还没有补充全面,其中就包括如何利用工具来监控调优前后的性能变化.工具做为图形化界面来展示更能直观的发现问题,另一方面一些耗 ...
- jvm系列(八):jvm知识点总览-高级Java工程师面试必备
在江湖中要练就绝世武功必须内外兼备,精妙的招式和深厚的内功,武功的基础是内功.对于武功低(就像江南七怪)的人,招式更重要,因为他们不能靠内功直接去伤人,只能靠招式,利刃上优势来取胜了,但是练到高手之后 ...
- jvm系列(四):jvm知识点总结
原文链接:http://www.cnblogs.com/ityouknow/p/6482464.html jvm 总体梳理 jvm体系总体分四大块: 类的加载机制 jvm内存结构 GC算法 垃圾回收 ...
随机推荐
- 属性(property)的特性(attribute)
属性:对象中可以保存数据的变量 属性的特性: 数据属性的特性(默认值是false):value.writable(可写否) .enumerable(可否枚举).configurable(可否重 ...
- 图像特征的提取(gaussian,gabor,frangi,hessian,Morphology...)及将图片保存为txt文件
# -*- coding: utf-8 -*- #2018-2-19 14:30:30#Author:Fourmi_gsj import cv2 import numpy as np import p ...
- oa项目环境搭建的操作步骤详解
dto:多表关联查询用单独建一个类,把查询数据放dto即可 vo:是view的缩写.单独定义一个类
- 正则re模块
正则表达式的特殊字符: 语法: re.match(正则语法,字符串) # re.match() 为关键字 group(1) # 取出第一个匹配 括号中的值,1位第一个括号内的值 1. 特殊字符 1 . ...
- 微信公众号之:JSSDK接入以及invalid signature等常见错误问题
最近在搞微信公众号开发,进行到网页开发部分被坑了一天,最坑的问题就是invalid signature,而网上大部分解答这个问题的都没有说清楚,都直接丢文档.博主认为这样很不好.本文是博主结合自身遇到 ...
- 拒绝频繁IP访问--转载
//首先我们要实现 IHttpModule接口 using System; using System.Collections.Generic; using System.Text; using Sys ...
- jquery源码 整体架构
一.对外提供接口 对外提供了jQuery. //可以通过jQuery或者$来找到jQuery (function(window,undefined){ //(21,94) 定义了一些变量和函数 jQu ...
- 多线程外排序解决大数据排序问题2(最小堆并行k路归并)
转自:AIfred 事实证明外排序的效率主要依赖于磁盘,归并阶段采用K路归并可以显著减少IO量,最小堆并行k路归并,效率倍增. 二路归并的思路会导致非常多冗余的磁盘访问,两组两组合并确定的是当前的相对 ...
- 剑指offer错题记录
错误重点: 1. 传递vector参数时,如果调用函数改变了vector的内容,一定一定要&,传引用保持一致 旋转数组的最小数字:有重复数字情况,二分查找照样搞.情况考虑要周全,当a[mid] ...
- centos 6.5升级内核到3.1
1.查看本机内核版本 [root@localhost ~]# uname -r 2.6.32-358.el6.x86_64 2.安装含有内核软件的源 步骤一:导入证书 [root@localhost ...