深入Java探索:Java内存区域
2023-03-14 22:51:49 时间
Java 内存划分:
在Java内存分配中,java将内存分为:方法区,堆,虚拟机栈,本地方法栈,程序计数器。其中方法区和堆对于所有线程共享,而虚拟机栈和本地方法栈还有程序计数器对于线程隔离的。每个区域都有各自的创建和销毁时间。 |
程序计数器:
作用是当前线程所执行的字节吗的行号指示器。Java的多线程是通过线程轮流切换并分配处理器执行时间方式来实现的。因此,每个线程为了能在切换后能恢复到正确的位置,每个线程需要独立的程序计数器。 |
Java 虚拟机栈:
每个放在被执行的时候都会同时创建一个栈帧用于存储局部变量表,操作数栈,动态链接,方法出口等信息。虚拟内存栈就是我们经常讲的“栈”。其中局部变量表所需内存是在编译期完成分配。 |
本地方法栈:
与虚拟机栈类似,区别在于虚拟机栈为虚拟机执行Java方法服务,而本地方法栈为虚拟机使用Native方法服务。 |
Java 堆:
被所有程序共享,并且在虚拟机启动时创建。此内存区域作用是存放对象实例。根据Java虚拟机规定,Java堆可以处于物理上不连续的内存空间,只要逻辑上连续即可。 |
方法区:
与堆相同,在各个线程间共享。作用是存储已被虚拟机加载的类信息,常量,静态变量,即时编译器编译后的代码等数据。 |
运行时常量池:
是方法区的一部分。作用是存储编译期生成的各种字面量和符号引用。 |
原文链接:http://www.cnblogs.com/brucewangxin/archive/2012/03/03/2378716.html
【编辑推荐】
- 深入Java虚拟机:Class文件实例解析
- Java中使用JDBC连接数据库例程与注意事项
- 同一段程序在Java和C中的不同结果
- Java中Runnable和Thread的区别
- Java对存储过程的调用方法
相关文章
- 最适合Java开发者的大数据工具和框架
- 深入理解Apache Flink核心技术
- Spark体系架构必读
- Spark SQL 究竟是何方神圣?
- java在处理大数据的时候一些小技巧
- 深入实践Spring Boot1.1.1 安装JDK
- 深入实践Spring Boot1.1.3 安装Apache Maven
- 深入实践Spring Boot1.2 创建项目工程
- 深入实践Spring Boot1.2.1 使用Maven新建项目
- 深入实践Spring Boot1.3.1 Maven依赖管理
- 深入实践Spring Boot1.4.2 将应用打包发布
- WOT2016杨大海:优酷土豆Hadoop集群挑战海量数据与高并发之道
- Java中8个顶级开源NoSQL数据库!
- java求字符串型逻辑表达式的bool值
- 深入实践Spring Boot2.4.1 Neo4j依赖配置
- Java程序员使用的20几个大数据工具
- 再谈java的内存泄露
- 随机数是骗人的,.Net、Java、C为我作证
- 介绍一个轻量级java的swf处理库
- 保持java线程间可见性的5种方式