标签:就会 erro 定义 地址 efi 字段 构造 src false
线程 运行数据区分为线程共享区和线程独占区
线程独占区的意思是每开启一个线程就会拥有一个线程独占区域
如下图所示:
程序计数器:
1)是一块较小的内存空间,可看做当前线程所执行的字节码的行号指示器
2)它处于线程独占区(每一个线程都会有自己的线程独占区)
3)如果线程执行的是java方法,这个计数器记录的就是正在执行的虚拟机字节码指令的地址,如果正在执行的是native方法,这个计数器的值为undefined
4) 此区域是唯一一个在java虚拟机规范中没有规定任何OutofMemory的情况的区域(开发者不操作程序计数器,由java虚拟机内部维护)
java虚拟机栈:
1)描述的是java方法执行的动态内存模型
2)栈帧:每个方法执行都会创建一个栈帧,伴随着方法从创建到执行完成。
栈帧用于存储局部变量表,操作数栈,动态链接,方法出口等。
3) 局部变量表:存放编译器可知的各种基本数据类型,引用类型。returnAddress类型;
局部变量表的内存空间在编译器完成分配,当进入一个方法时,这个方法需要帧分配多少内存是固定的,在方法运行期间是不会改变局部变量表的大小
4)栈大小问题: 栈满抛StackOverFlowError 栈内存溢出
OutofMerory
本地方法栈:虚拟机栈为虚拟机执行java方法服务;本地方法栈为虚拟机执行native方法服务
java堆:
1)存放对象实例(并非所有对象实例都被存放在堆中)
2)是垃圾收集器管理的主要区域
3)新生代,老年代,Eden空间
方法区:
1)存储虚拟机加载的类信息(包括类的版本,字段,方法,接口等描述信息),常量,静态变量,即时编译器编译之后的代码等数据
2)方法区和永久代(这两者在HotSpot中是等价的)
3)垃圾回收在方法区的行为
4)异常定义:申请失败会抛出OutofMemoryError
运行时常量池(属于方法区中的一块)
对象的创建:
方式:new关键字--》存储到java堆中
遇到问题:
1)给对象分配内存:
指针碰撞法(java堆use和free很规整时使用);
空闲列表法(使用一张表来进行记录哪些内存未使用)
2)线程安全性问题
采用线程同步方式解决;
采用本地线程分配缓冲(TLAB) 来提高一些性能
3)初始化对象
初始化之后:
抽象数据类型默认为null; 基本数据类型默认为0;boolean型默认为false
4)执行构造方法
探究对象结构:
对象的访问定位:(如何找到对象)
1)使用句柄
2)直接指针,速度快,减少性能开销
标签:就会 erro 定义 地址 efi 字段 构造 src false
原文地址:https://www.cnblogs.com/zjf-293916/p/9251590.html