Java虚拟机内存模式学习笔记
2016-09-12 11:13
190 查看
一 可能相关的概念
[摩尔定理]: 当价格不变时,集成电路上可容纳的晶体管个数,约没相隔18个月便会增长一倍,性能也将提升一倍。
[java 虚拟机内存处理]:java虚拟机里的内存模型中定义的访问操作和物理计算机处理的方式基本一致。
[java虚拟机和多线程]:java多线程机制使得多个任务同时执行处理。所有的线程共享JVM内存区域主存,而每个线程又有自己的工程内存。当线程与进行交互时,数据从主存拷贝到工作的工程内存,进而交由线程处理。
二 Java虚拟机内存组成
1.程序计数器:当前线程所执行的字节码的行号指示器。字节码解释器就是通过改变这个计数器的值来选取下一条需要执行的字节码指令。分支,循环,跳转,异常处理,线程恢复等逻辑功能都是通过程序计数器的值的改变来实现。Java虚拟机通过线程轮流的切换并分配处理器执行的时间来实现多线程调度。在任何一个确定的时刻,一个处理器只会执行一条线程中的指令。
每条线程都会有自己独立的程序计数器,所以程序计数器是[线程私有]。
2.java虚拟机栈内存:[线程私有],与线程生命周期一致。虚拟机栈体现了java方法执行时内存工作模式:每一个方法被执行的同时会创建一个栈帧,操作栈,动态链接,方法出口。
3.本地方法栈:为虚拟机使用到的native方法服务
4.Java堆:所有线程共享,存放对象实例,几乎所有的对象实例都在这里分配内存。
5.方法区:所有线程共享,存储被虚拟机加载的类信息,常量,静态变量以及编译器编译后的代码。
6.运行时常量池:用于存储编译时生成的常量和引用
[摩尔定理]: 当价格不变时,集成电路上可容纳的晶体管个数,约没相隔18个月便会增长一倍,性能也将提升一倍。
[java 虚拟机内存处理]:java虚拟机里的内存模型中定义的访问操作和物理计算机处理的方式基本一致。
[java虚拟机和多线程]:java多线程机制使得多个任务同时执行处理。所有的线程共享JVM内存区域主存,而每个线程又有自己的工程内存。当线程与进行交互时,数据从主存拷贝到工作的工程内存,进而交由线程处理。
二 Java虚拟机内存组成
1.程序计数器:当前线程所执行的字节码的行号指示器。字节码解释器就是通过改变这个计数器的值来选取下一条需要执行的字节码指令。分支,循环,跳转,异常处理,线程恢复等逻辑功能都是通过程序计数器的值的改变来实现。Java虚拟机通过线程轮流的切换并分配处理器执行的时间来实现多线程调度。在任何一个确定的时刻,一个处理器只会执行一条线程中的指令。
每条线程都会有自己独立的程序计数器,所以程序计数器是[线程私有]。
2.java虚拟机栈内存:[线程私有],与线程生命周期一致。虚拟机栈体现了java方法执行时内存工作模式:每一个方法被执行的同时会创建一个栈帧,操作栈,动态链接,方法出口。
3.本地方法栈:为虚拟机使用到的native方法服务
4.Java堆:所有线程共享,存放对象实例,几乎所有的对象实例都在这里分配内存。
5.方法区:所有线程共享,存储被虚拟机加载的类信息,常量,静态变量以及编译器编译后的代码。
6.运行时常量池:用于存储编译时生成的常量和引用
相关文章推荐
- java对世界各个时区(TimeZone)的通用转换处理方法(转载)
- java-注解annotation
- java-模拟tomcat服务器
- java-用HttpURLConnection发送Http请求.
- java-WEB中的监听器Lisener
- Android IPC进程间通讯机制
- Android Native 绘图方法
- Android java 与 javascript互访(相互调用)的方法例子
- 介绍一款信息管理系统的开源框架---jeecg
- 聚类算法之kmeans算法java版本
- java实现 PageRank算法
- PropertyChangeListener简单理解
- c++11 + SDL2 + ffmpeg +OpenAL + java = Android播放器
- 插入排序
- 冒泡排序
- 堆排序