本文介绍: ps:jdk8运行时数据区指的是JVM所管理的内存区域,其中分成两大类:线程共享 –方法区、堆方法区:存放每一个加载的类的元信息、运行时常量池、字符串常量池。堆:存放创建出来的对象。线程不共享 –本地方法栈、虚拟机栈、程序计数器本地方法栈和虚拟机栈都存放了线程中执行方法时需要使用的基础数据。程序计数器存放了当前线程执行的字节码指令在内存中的地址。直接内存主要是NIO使用,由操作系统直接管理,不属于JVM内存。

 紧接上篇:JVM运行时数据区(上篇)-CSDN博客 

  • 一般Java程序中堆内存是空间最大的一块内存区域。创建出来的对象都存在于堆上。
  • 栈上的局部变量表中,可以存放堆上对象的引用。静态变量也可以存放堆对象的引用,通过静态变量就可以实现对象在线程之间共享。
  • 字符串常量池,存储字符串的常量。

  • 堆空间有三个需要关注的值,used total max。
  • used指的是当前已使用的堆内存,total是java虚拟机已经分配的可用堆内存,max是java虚拟机可以分配的最大堆内存。
  • 当total达到max时说明可分配内容已满,注意此时并不代表OOM!

方法区

方法区是Java虚拟机规范中提出来的一个虚拟机概念,在HotSpot不同版本中会用永久代或者元空间来实现。方法区主要存放的是基础信息,包含:

  • 每一个加载的类的元信息(基础信息)。
  • 运行时常量池,保存了字节码文件中的常量池内容,避免常量内容重复创建减少内存开销。
ps:jdk1.8

总结

ps:jdk8

运行时数据区指的是JVM所管理的内存区域,其中分成两大类:

  • 线程共享 – 方法区、堆
    • 方法区:存放每一个加载的类的元信息、运行时常量池、字符串常量池。
    • 堆:存放创建出来的对象。
  • 线程不共享 – 本地方法栈、虚拟机栈、程序计数器
    • 本地方法栈和虚拟机栈都存放了线程中执行方法时需要使用的基础数据。
    • 程序计数器存放了当前线程执行的字节码指令在内存中的地址。
    • 直接内存主要是NIO使用,由操作系统直接管理,不属于JVM内存。

原文地址:https://blog.csdn.net/weixin_54498224/article/details/135573682

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。

如若转载,请注明出处:http://www.7code.cn/show_57214.html

如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱:suwngjj01@126.com进行投诉反馈,一经查实,立即删除!

发表回复

您的电子邮箱地址不会被公开。 必填项已用 * 标注