JVM内存结构
jvm将虚拟机分为5大区域,分别是程序计数器、虚拟机栈、本地方法栈、Java堆、方法区
1、方法区:存放已被加载的类的信息、常量、静态变量、就是编译器编译后的代码数据,后来在jdk1.8后编程了元数据区代替,方法区被分成两部分分别是:加载的类信息、运行时常量池,这个运行时常量池包存在堆中
2、堆:Java堆是所有线程共享的一块内存,几乎所有对象的实例和数组都要在堆上分配内存,因此该区域经常发生垃圾回收操作
3、本地方法栈:线程私有,保存native方法的信息,当一个jvm创建的线程调用native方法后,jvm不会在虚拟机中为该线程创建栈贞,而是简单的动态连接并直接调用该方法
4、虚拟机栈:线程私有,每个方法执行的时候都会创建一个栈贞,用于储存局部变量表、操作数、动态链接和方法的返回等等,当线程的请求深度超过了虚拟机允许的最大深度是,就会抛出StackOverFlowError
5、程序计数器:线程私有,是一块很小的内存空间,作为当前线程的行号指示器,用于记录当前虚拟机正在执行的线程指令地址
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/5074.html