Java存储区域——JVM札记<一个>
Java当虚拟机数据区域
执行数据区主要包括:方法区、堆、VM栈、本地方法栈、程序计数器。
当中方法区和栈是线程共享的区域,另外三块区域是每一个线程私有的区域。各个数据区的功能简单说明例如以下:
程序计数器:当前线程所运行的字节码的行号指示器。
虚拟机栈:描写叙述Java方法运行的内存模型——每个方法在运行的同一时候都会创建一个栈帧用于存储局部变量表、操作数栈、动态链接、方法出口等信息。每个方法从调用直至运行完毕的过程。就相应一个栈帧在虚拟机栈中入栈到出栈的过程。假设栈的深度大于虚拟机所同意的深度,将抛出StackOverflowError异常。假设栈扩展时无法申请到足够的内存,将抛出OutOfMemoryError异常(下述的本地方法栈类同)。
本地方法栈:与虚拟机栈的作用类似。虚拟机栈为Java方法服务,本地方法栈为Native方法服务。
Java堆:在虚拟机启动的时候创建。作用是存放对象实例。通过-Xmx和-Xms控制堆的大小。假设在堆中没有内存完毕实例分配,而且堆也无法再扩展时。将抛出OutOfMemoryError异常。
方法区:作用是存储已被虚拟机载入的类信息、常量、静态变量等(在HotSpot中称此区域为Permanent Generation)。
对象的创建
对象的创建包含四个步骤:类载入检查、为新生对象分配内存、初始化为零值、设置对象头。
一、类载入检查
虚拟机遇到一条new指令时,收件将检查该指令的參数能否在常量池(执行时常量池是方法区的一部分。
Class文件除了有类的版本号、字段、方法、接口等描写叙述信息外,另一项信息是常量池,用于存放编译期生成的各种字面量和符号引用,这部分内容将在类载入后进入方法区的执行时常量池中存放。)中定位到一个类的符号引用,而且检查这个符号引用代表的类是否已被载入、解析和初始化过。
假设没有,那必须先执行对应的类载入过程。
二、为新生对象分配内存
对象所需内存大小在类载入完毕后便全然确定。则分配内存等同于把一块确定大小的内存从Java堆中划分开来。
分两种情况:Java堆中内存是绝对规整的(称为指针碰撞。Bump the pointer)、内存不规整(称为空暇列表。Free List)。在规整的Java堆中,用过的内存放一边,空暇的内存放一边。中间放一个指针作为分界点。在不规整的Java堆中,虚拟机维护一个列表记录哪些块是可用的。选择那种分配方式由Java堆是否规整决定。而Java堆是否规整由採用的垃圾收集器是否带有压缩整理功能决定。如:在使用Serial、ParNew等带Compact过程的收集器时,採用的分配算法是指针碰撞。而使用CMS基于Mark-Sweep算法的收集器时,採用空暇列表。
三、分配内存过程须要保证线程安全
对分配内存空间的动作进行同步处理。或者是把内存分配的动作依照线程划分在不同的空间进行(即本地线程分配缓冲Thread Local Allocation Buffer)。
四、对象头的设置
说明是哪个类的实例、怎样找到类的元数据信息、对象的哈希码、对象的GC年龄。
对象的訪问定位
Java程序通过栈上得reference数据操作堆上得详细对象。有两种訪问方式:使用句柄和直接指针。
一、使用句柄
reference中存储的是稳定的句柄地址。在对象实例数据被移动时(垃圾回收时)仅仅会改变句柄中的实例数据指针,而reference本身不须要改变。
二、使用直接指针
速度快,由于它节省了一次指针定位的时间开销。
说明:本文的内容參考书籍《深入理解Java虚准机(文章2版本)》
版权声明:本文博客原创文章,博客,未经同意,不得转载。
Java存储区域——JVM札记<一个>的更多相关文章
- Java内存管理:Java内存区域 JVM运行时数据区
转自:https://blog.csdn.net/tjiyu/article/details/53915869 下面我们详细了解Java内存区域:先说明JVM规范定义的JVM运行时分配的数据区有哪些, ...
- JVM性能优化系列-(1) Java内存区域
1. Java内存区域 1.1 运行时数据区 Java虚拟机在执行Java程序的过程中会把它所管理的内存划分为若干个不同的数据区域.主要包括:程序计数器.虚拟机栈.本地方法栈.Java堆.方法区(运 ...
- [Java] Java 技术和 JVM 基础
Java 由 Sun 公司在 1995 首次发布,既是一门编程语言,也是一个计算平台. Java 运行时版本 Java Runtime Edition 当你下载 Java 完时候,你会得到一个 Jav ...
- IT兄弟连 Java语法教程 Java开发环境 JVM、JRE、JDK
要想开发Java程序,就需要知道什么是JVM.JRE以及JDK.JVM是运行Java程序的核心,JRE是支持Java程序运行的环境,而JDK是Java开发的核心,下面我们分别具体介绍它们以及它们之间的 ...
- java虚拟机学习-JVM内存管理:深入Java内存区域与OOM(3)
概述 Java与C++之间有一堵由内存动态分配和垃圾收集技术所围成的高墙,墙外面的人想进去,墙里面的人却想出来. 对于从事C.C++程序开发的开发人员来说,在内存管理领域,他们即是拥有最高权力的皇帝又 ...
- JVM自动内存管理-Java内存区域与内存溢出异常
摘要: JVM内存的划分,导致内存溢出异常的可能区域. 1. JVM运行时内存区域 JVM在执行Java程序的过程中会把它所管理的内存划分为以下几个区域: 1.1 程序计数器 程序计数器是一块较小的内 ...
- Java内存区域与内存溢出异常(JVM学习系列1)
相对于C.C++等语言来说,Java语言一个很美好的特性就是自动内存管理机制.C语言等在申请堆内存时,需要malloc内存,用完还有手动进行free操作,若程序员忘记回收内存,那这块内存就只能在进程退 ...
- JVM参数配置 java内存区域
java内存区域 一些基本概念 http://www.importnew.com/18694.html https://www.cnblogs.com/wangyayun/p/6557851.html ...
- JVM系列1:Java内存区域
JVM系列主要分享自己都虚拟机的理解,我自学时的知识框架多来源于<深入理解Java虚拟机_JVM高级特性与最佳实践>这本书,感兴趣的朋友可直接去阅读这本书. 本系列暂定有3部分,它们是学习 ...
随机推荐
- 玩转Web之servlet(四)---B/S是如何使用http协议完成通信过程的
在上一篇文章中,我简单的说了一下B/S架构的流程图,关于浏览器和服务器之间的通信过程知识含糊的说了一下,在这篇文章中我再总结一下B/S架构里是如何利用http协议去完成通信的. (一)通讯过程 1:浏 ...
- android存储阵列数据SharedPreferences
假设要数组数据(如boolean[] .int[]等)到SharedPreferences时,我们能够先将数组数据组织成json数据存储到SharedPreferences,读取时则对json数据进行 ...
- python udp编程实例
与python tcp编程控制见 http://blog.csdn.net/aspnet_lyc/article/details/39854569 c++ udp/tcp 编程见 http://blo ...
- 采用truelicense进行Java规划license控制 扩展可以验证后,license 开始结束日期,验证绑定一个给定的mac住址
采用truelicense进行Java规划license控制 扩展可以验证后,license 开始结束日期,验证绑定一个给定的mac住址. Truelicense 它是一个开源java license ...
- [Linux]scp 命令远程复制
这些天来干预系统之前没有接触,建立使用用途良好的发展环境 scp命令,那么如何使用查询以下信息. scp是secure copy的缩写.主要用来linux系统之间的文件和文件夹的远程拷贝 能够非常ea ...
- 得知Android小遴选程序第七头(他们定义对话框、Gallery、ImageSwitcher)
效果如下面的: 一共一个activity和两个xml. ******当我们须要使用的组件不在setContentView()设置的布局文件里,那我们就须要使用inflate()方 ...
- 认识node.js:express(一)
express是node.js官方推荐的框架. 安装 npm install express -g 命令中的 “-g” 表示全局(global) 由于新版本(4.x.x)的express的命令集中到了 ...
- [LeetCode234]Palindrome Linked List
题目: Given a singly linked list, determine if it is a palindrome. 判断一个单链表是不是回文 思路: 1.遍历整个链表,将链表每个节点的值 ...
- dev layoutControl 控件使用
对于排版控件,用微软的方法都是先拉 label再拉一个 Textbox , 虽然微软的控件了有类似于 EXCEL的单元格全并功能,但用起来使终不方便, 今天研究了一下 DEV 的这个控件,比微软的 ...
- 使用 svn+maven+jenkins(hudson)+Publish Over SSH plugins 构建持续集成及自动远程发布体系(转)
1.安装jenkins 2.浏览器访问jenkins主页 http://192.168.0.1:8080/,点击“系统管理” 3.在插件管理中,安装Publish Over SSH插件 4.在系统设置 ...