参考资料

本文参考:《深入理解Java虚拟机》作者 周志明 知识产权归作者所有

走近java

  1. java组成部分:java语言、各平台虚拟机、Class文件结构、java api 类库、第三方类库
  2. Jre包括jvm和api
  3. java 未来展望:模块化、混合语言、多核并行、丰富语法、64位虚拟机

自动内存管理机制

PC程序计数器

PC:程序计数器,用于记录和控制下一条需要执行的字节码的位置,分支、循环、跳转、异常处理、线程恢复都需要依赖PC完成。
PC 是每个线程私有的,如果执行的是java方法,该值是字节码指令的地址,如果是native方法,该值是Undefined

Java虚拟机栈

JVM Stack 线程私有,用于存放栈帧 Frame 包括局部变量表、操作数栈、动态链接、方法出口等信息,如果线程请求的栈深度大于虚拟机所允许的深度,将抛出StackOverflowError异常,如果Stack可以动态扩展,扩展到无法申请到足够的内存时,抛出OutOfMemory'Error异常。-Xss 设置栈容量

Java堆

Heap 堆是线程共享 用于分配对象实例 -Xms10m 初始大小 -Xmx20m 最大大小 也包括线程私有的分配缓冲区 TLAB
方法区 Method Area 线程共享 用于存储被JVM加载的类信息、常量、静态变量、JIT后的代码,又叫做非堆 Non-Heap,永久代,-XX:PermSize=64M JVM初始分配的非堆内存,-XX:MetaspaceSize,class metadata的初始空间配额,以bytes为单位,jdk1.7,符号引用(Symbols)转移到了native heap;字面量(interned strings)转移到了java heap;类的静态变量(class statics)转移到了java heap;在JDK8中,classe metadata(the virtual machines internal presentation of Java class),被存储在叫做Metaspace的native memory。

运行时常量池

常量池是方法区的一部分,由Class文件解析后完成。

DirectMemory 或 Native Memory

JDK1.4引入的NIO可以使用Native函数直接分配堆外内存,然后通过DirectByteBuffer对象对这块内存直接操作,避免了在Heap和NativeHeap直接来回复制数据,在设置-Xmx参数时要注意留出NativeMemory空间。

JDK1.6的intern方法把首次出现的字符串实例复制到永久代中,并返回已复制的实例引用

JDK1.7的intern方法不会再复制实例、而只是在常量池中记录首次出现的实例引用,因此intern返回的引用和调用者是同一个引用。

创建对象分配内存方式:

  1. 指针碰撞,移动已使用内存和空闲内存之间的指针,前提是已使用和空闲内存比较规整。
  2. 空闲列表,记录可用内存块及大小。
  3. 内存分配的同步问题:使用CAS + 失败重试 保证内存分配的原子性,或利用TLAB,现在TLAB上分配,使用完分配新的TLAB时才需要同步
  4. 分配完成后内存空间全部初始化为零值

对象的内存布局

布局:对象头Header、实例数据Instance Data 对齐填充 Padding 疑问:为什么JVM对象地址要8字节对齐?
对象头包括MarkWord和类型指针,MarkWord 32bit or 64bit 包括哈希码、GC分代年龄、锁状态标记、线程持有的锁、偏向线程ID、偏向时间戳
类型指针是非必须的、以来虚拟机实现、如果是Java数组、对象头还包括数组长度。
实例数据:父类变量在子类变量之前。CompactFields = true 子类较窄变量会插到父类变量的空隙之间。

对象的访问定位

  1. 使用句柄访问:在Java堆中划分出一块内存做句柄池 reference中存储的是对象的句柄地址,而句柄中包含了对象实例地址和类型数据地址
  2. 使用对象指针访问:reference中存储的是对象地址,需要考虑的是对象布局中如何放置访问类型数据的指针

各种区域溢出现象

Java堆溢出 -XX:+HeapDumpOnOutOfMemoryError ava.lang.OutOfMemoryError: Java heap space
使用Eclipse Memory Analyzer 进行分析,内存泄露 查看泄露对象到GC Roots的引用链

Stack溢出 stack length unable to create new native thread

方法区和运行时常量池溢出 提示PermGen space

DirectMemory溢出时明显的特征是dump文件中看不见明显的异常、文件很小,请检查是否有NIO调用。

JVM学习笔记一:内存管理的更多相关文章

  1. linux kernel学习笔记-5内存管理_转

    void * kmalloc(size_t size, gfp_t gfp_mask); kmalloc()第一个参数是要分配的块的大小,第一个参数为分配标志,用于控制kmalloc()的行为. km ...

  2. XV6学习笔记(2) :内存管理

    XV6学习笔记(2) :内存管理 在学习笔记1中,完成了对于pc启动和加载的过程.目前已经可以开始在c语言代码中运行了,而当前已经开启了分页模式,不过是两个4mb的大的内存页,而没有开启小的内存页.接 ...

  3. JVM读书笔记之内存管理

    对于从事C.C++程序开发人员来说,在内存管理领域,他们既是拥有最高权力的“皇帝”又是从事最基础工作的“劳动人民”--既拥有每一个对象的“所有权”,又负责每一个对象生命开始到终结的维护责任. 对于Ja ...

  4. COCOS学习笔记--Cocod2dx内存管理(三)-Coco2d-x内存执行原理

    通过上两篇博客.我们对Cocos引用计数和Ref类.PoolManager类以及AutoreleasePool类已有所了解,那么接下来就通过举栗子来进一步看看Coco2d-x内存执行原理是如何的. / ...

  5. 嵌入式linux学习笔记1—内存管理MMU之虚拟地址到物理地址的转化

    一.内存管理基本知识 1.S3C2440最多会用到两级页表:以段的方式进行转换时只用到一级页表,以页的方式进行转换时用到两级页表.页的大小有三种:大页(64KB),小页(4KB),极小页(1KB).条 ...

  6. Linux内核学习笔记——内核内存管理方式

    一 页 内核把物理页作为内存管理的基本单位:内存管理单元(MMU)把虚拟地址转换为物理 地址,通常以页为单位进行处理.MMU以页大小为单位来管理系统中的也表. 32位系统:页大小4KB 64位系统:页 ...

  7. ios学习笔记之内存管理

    一,内存管理类型定义      1,基本类型  任何C的类型,eg:      int,short,char,long,long long,struct,enum,union等属于基本类型或结构体   ...

  8. Cocos2D-X2.2.3学习笔记3(内存管理)

    本章节介绍例如以下: 1.C/C++内存管理机制 2.引用计数机制 3.自己主动释放机制 1.C/C++内存管理机制 相信仅仅要懂oop的都知道NEW这个keyword吧,这个通俗点说事实上就是创建对 ...

  9. arm-linux学习笔记3-linux内存管理与文件操作

    配置好linux系统之后需要vim配置一下,有助于我们的编程,主要的配置如下 在/etc/vim/vimrc文件中 "显示行号 set number "自动缩进 set autoi ...

  10. 《C#高级编程》学习笔记----c#内存管理--栈VS堆

    本文转载自Netprawn,原文英文版地址 尽管在.net framework中我们不太需要关注内存管理和垃圾回收这方面的问题,但是出于提高我们应用程序性能的目的,在我们的脑子里还是需要有这方面的意识 ...

随机推荐

  1. 黄油刀ButterKnife的使用

    1.ButterKnife是一个由JakeWharton写的开源框架,它使用注解处理将属性和方法和View绑定,以生成模板代码. 2.作用: @1通过使用@BindView 注释属性取消了findVi ...

  2. Bash的作业控制

    作业控制是bash Shell提供的一项强大功能,它允许你选择在前台还是后台运行程序,即作业. 1.开启bash的作业控制功能 #set -o monitor或#set -m 2.显示在后台运行的作业 ...

  3. C++汉诺塔递归实现

    程序背景: 汉诺塔(Tower of Hanoi)又称河内塔,问题是源于印度一个古老传说的益智玩具.大梵天创造世界的时候做了三根金刚石柱子,在一根柱子上从下往上按照大小顺序摞着64片黄金圆盘.大梵天命 ...

  4. jquery.qrcode.min.js(支持中文转化二维码)

    详情请看:http://www.ncloud.hk/%E6%8A%80%E6%9C%AF%E5%88%86%E4%BA%AB/jqueryqrcodeminjs/ 今天还是要讲一下关于二维码的知识,前 ...

  5. [POI2005]SAM-Toy Cars

    题目描述 Johnny is a little boy - he is only three years old and enjoys playing with toy cars very much. ...

  6. Strom序列化机制

    Storm 中的 tuple可以包含任何类型的对象.由于Storm 是一个分布式系统,所以在不同的任务之间传递消息时Storm必须知道怎样序列化.反序列化消息对象. Storm 使用 Kryo库对对象 ...

  7. NoSQL数据库:Redis适用场景及产品定位

    传统MySQL+ Memcached架构遇到的问题 实际MySQL是适合进行海量数据存储的,通过Memcached将热点数据加载到cache,加速访问,很多公司都曾经使用过这样的架构,但随着业务数据量 ...

  8. TPYBoard自制微信远程智能温湿度计

    智能时代一夜间什么都能远程了.创业者想着如何做智能产品,如何做远程控制.DIY爱好者也想着如何自制各种奇妙的工具.这里和大家一起学习制作一款廉价的智能温湿度计.说它廉价是因为共计花费不过40元,说它智 ...

  9. VS2012打开项目 提示Asp.net4.5未在web服务器上注册

    在用vs2012代开项目时,没回都显示Asp.net4.5未在web服务器上注册,最后是由于没有下载一个补丁的原因,只需要下载安装补丁 VS11-KB3002339.exe ,下载地址:https:/ ...

  10. LINQ TO SQL和Entity Framework 的关系 你了解多少?

    1. LINQ  TO SQL  和EF 特点:  LINQ TO SQL和Entity Framework都是一种包含LINQ功能的ORM 也就是所谓的关系对象的映射.其中包括的有DBFrist   ...