当前位置: 移动技术网 > 科技>人工智能>机器学习 > JVM运行时数据区记录

JVM运行时数据区记录

2020年10月24日  | 移动技术网科技  | 我要评论
提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档文章目录前言一、pandas是什么?二、使用步骤1.引入库2.读入数据总结前言提示:这里可以添加本文要记录的大概内容:例如:随着人工智能的不断发展,机器学习这门技术也越来越重要,很多人都开启了学习机器学习,本文就介绍了机器学习的基础内容。提示:以下是本篇文章正文内容,下面案例可供参考一、pandas是什么?示例:pandas 是基于NumPy 的一种工具,该工具是为了解决数据分析任务而创建的。二、使用步骤1.引入库代码

前言

记录JVM运行时数据区相关1.1。


JVM运行时数据区

在这里插入图片描述

1.线程私有

程序计数器、虚拟机栈、本地方法栈

程序计数器

当CPU为当前线程分配的时间片使用完后,会去执行其他线程任务,因此需要线程上有一块区域专门用来记录当前程序执行到哪一行,等线程被下次CPU调度的时候接着执行,该区域就是程序计数器,且线程私有。

虚拟机栈

虚拟机栈描述的是Java方法执行的线程内存模型: 当一个方法被执行的时候, Java虚拟机会在虚拟机栈中同步创建一个栈帧与之对应 用于存储局部变量表、 操作数栈、 动态连接、 方法出口等信息。 每一个方法被调用直至执行完毕的过程, 就对应着一个栈帧在虚拟机栈中从入栈到出栈的过程。

本地方法栈

本地方法栈与虚拟机栈所发挥的作用是非常相似的,简单描述就是 调用Java方法时使用的是虚拟机栈,调用本地native方法时使用的是本地方法栈。

2.线程共享

JAVA堆、方法区

JAVA堆

Java堆空间是虚拟机垃圾回收的主要区域、同时几乎所有对象实例都是在堆上分配内存(一些对象实例可以在栈上分配),从垃圾回收的角度来说,堆空间又可分为新生代和老年代。
注意的是:堆空间不全是共享的,JVM为每个线程在新生代中Eden区分配了一个较小的私有缓存区域TLAB。这样不仅能避免多线程操作共享资源时存在的线程安全问题,还能提升内存分配的吞吐量
在这里插入图片描述

方法区

方法区与堆空间一样是属于线程共享的,它用于存储已被虚拟机加载的类型信息、 常量、 静态变量、 即时编译器编译后的代码缓存等数据。在JDK1.7的时候,方法区的实现被称为永久代,JDK1.8的时候,方法区的实现被元空间替代,永久代和元空间都是方法区的实现,其最主要的区别就是元空间不在虚拟机设置的内存中,而是使用的本地内存

小结

  1. JVM运行时数据区主要有几部分以及他们的主要作用
  2. 实例对象不全是分配在堆空间上的,一些实例对象可分配在栈上
  3. 堆内存区域不全都是线程共享

本文地址:https://blog.csdn.net/q504395191/article/details/109180303

如您对本文有疑问或者有任何想说的,请点击进行留言回复,万千网友为您解惑!

相关文章:

验证码:
移动技术网