java学习一:jvm内存分配

JVM主要模块

类装载器:启动类装载器和用户类装载器。

一个类可能会引用另外一个类,被引用的类和引用的类会用同一个装载器装载,不同装载器装载的类无法互相访问,因此每一个装载器都有自己的命名空间。

执行引擎

实现方式

  1. 解释执行
  2. just in time:第一次执行的字节码会被编译成本地代码,然后被缓存调用。缺点是占用内存
  3. 自适应优化器:频繁被调用的字节码才会被编译成本地代码
  4. 硬件实现

运行JVM字节码的工作是由装载器和执行引擎来完成的。解释执行过程分三部进行:代码的装入、代码的校验和代码的执行(c++是编译、链接和执行)。

如果把Java原程序想象成我们的C++原程序,Java原程序编译后生成的字节码就相当于C++原程序编译后的80x86的机器码(二进制程序文件),JVM虚拟机相当于80x86计算机系统,Java解释器相当于80x86CPU。在80x86CPU上运行的是机器码,在Java解释器上运行的是Java字节码。

对比
java源程序c++源程序
字节码机器码
jvm虚拟机8086计算机
java解释器8086cpu

 


Java运行时数据区

简单通俗的讲,一个完整的Java程序运行过程会涉及以下内存区域:

pc寄存器:JVM内部虚拟寄存器,存取速度非常快,程序不可控制。

java虚拟机栈:保存局部变量表,操作栈,动态链接,方法出口等。局部变量表包括:1.用来保存基本数据类型的值;2.保存堆区对象的引用(指针),3.returnAddress类型(字节码指令地址)。也可以用来保存加载方法时的帧。

本地方法栈:为调用本地方式服务的内存区域。

堆:线程共享的。

用来存放动态产生的数据,几乎所有的对象实例都会在这里分配。注意创建出来的对象只包含属于各自的成员变量,并不包括成员方法。因为同一个类的对象拥有各自的成员变量,存储在各自的堆中,但是他们共享该类的方法,并不是每创建一个对象就把成员方法复制一次。

方法区(包含常量池):线程共享的。可以在堆顶实现方法区。JVM为每个已加载的类类型保存:

类型信息包括:类名、修饰符、父类、接口列表、类还是接口信息。

运行时常量池:

数据来源:

java文件编译生成的class文件会有存放常量信息,包括:字面量和符号应用。在加载该class文件时,这部分信息就存放到运行时常量池中。

其次,运行时也可以向运行时常量池添加数据,String.intern()。

数据类型

常量池包括直接常量(基本类型,String)和对其他类型、方法、字段的符号引用。池中的数据和数组一样通过索引访问。

域信息:成员变量名、变量类型、修饰符

方法信息:方法名、方法返回类型、参数的数量和类型、修饰符、字节码(非本地)、局部变量大小、异常表。

类变量、类ClassLoader的引用、

Class类的引用。 

直接内存:主要是NIO时会用到


对象访问方式:

通过句柄和直接指针访问

引用类型变量要在栈区和堆区各占一块内存。(c++中的指针类似)


参考链接:http://blog.csdn.net/shimiso/article/details/8595564#comments


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值