关于Java虚拟机二三事(一)---Java技术体系及JVM内存结构

2024-08-23 01:58

本文主要是介绍关于Java虚拟机二三事(一)---Java技术体系及JVM内存结构,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

前言

作为一个爱好Java的程序猿,自然少不了对JVM的学习和研究,《深入理解Java虚拟机》一书,大概从头到尾完整地看了四五遍,有些地方感觉讲的粒度比较粗,但只是少数,总体而言,这本书讲解的非常棒,不少东西都是看了第二次,甚至第三次之后才有了进一步的理解。

走进Java-Java技术体系

从广义上讲,Clojure、JRuby、Groovy等运行于Java虚拟机上的语言及其相关程序都属于Java技术体系中的一员。但是,如果仅从传统意义上看,Sun官方所定义的Java 技术体系包括以下几个组成部分。

  • Java程序设计语言
  • 各种硬件平台上的Java虚拟机
  • Java API类库
  • Class文件格式
  • 来自商业机构及开源社区的第三方Java类库

    这里,还可以进一步细分,
    Java体系

      其中,JVM(Java Virtual Machine,Java虚拟机)可以说是支撑整个Java技术体系运行的关键所在。下图是Java虚拟机的整体结构,主要描述的是从编写好的Java代码(.java文件),经过编译器编译形成字节码文件(.class文件),字节码文件通过类加载器加载到运行时数据区中,并由执行引擎按照代码执行顺序逐步执行。

    Java虚拟机

      不同于C/C++,Java程序员将内存控制的权力交给了Java虚拟机,因此,为了能够更好的了解虚拟机对内存的使用,以及对内存泄漏和溢出等方面问题的定位,有必要深入理解Java虚拟机的内存管理机制。

      而Java虚拟机最主要的内存区域,便是运行时数据区,也就是下图中红色箭头所指的区域(Runtime Data Areas)。

运行时数据区

  这部分区域,便是Java程序在运行时,所有涉及的变量、方法、对象存储的地方。我们可以通过下图更进一步了解运行时数据区的内部结构划分。
  
运行时数据区结构

从上图可知,运行时数据区总共分为5部分:方法区、虚拟机栈、本地方法栈、堆、程序计数器。下面将简单介绍一下各部分在运行时数据区中的主要作用。后续将做进一步的详细介绍。
  1.程序计数器:
  程序计数器是一块较小的内存空间,它可以看做是当前线程所执行的字节码的行号指示器,如果了解计算机处理器内部结构的同学,其实可以很容易理解,处理器中会有32个32位的寄存器,寄存器是用来进行各类计算的基本单元,而程序计数器本质便是一个32位的寄存器,它存放的是当前字节码执行的行号,同时利用程序计数器,也能够定位到下一句即将执行的语句。
   又因为Java虚拟机的多线程是通过线程轮流切换并分配处理器执行时间的方式来实现的,因此在任何一个确定的时刻,一个处理器都只会执行一条线程。因此,为了线程切换后能够恢复到正确的执行位置,每条线程都需要一个独立的程序计数器,各条线程之间的计数器互不影响,独立存储,我们称这类内存区域为“线程私有”的内存。
   2.Java虚拟机栈:
   与程序计数器一样,虚拟机栈也是线程私有的,虚拟机栈主要描述的是Java方法执行的内存模型,每个方法在执行的同时,会创建一个栈帧,每个栈帧用于存储局部变量表、操作数栈、动态链接、方法出口信息等。而方法从调用到完成的阶段,就是入栈到出栈的过程。
   3.本地方法栈:
   本地方法栈与虚拟机栈的作用非常相似,他们之间区别不过是虚拟机栈为虚拟机执行Java方法提供服务,而本地方法栈则是为虚拟机使用到的Native方法服务。
   4.Java堆:
   对于大多数应用来说,Java堆是Java虚拟机中所管理内存中最大的一块,因为Java堆中存放了所有的对象实例和数组。且Java堆被所有线程所共享,在虚拟机启动的时候会自动创建,这块区域也是垃圾回收时的重点区域。
   5.方法区:
   方法区与Java堆一样,被各个线程所共享内存,它用于存储虚拟机加载的类信息、常量、静态变量、即时编译器变异后的代码等数据。这里需要额外提及的是运行时常量池,它是方法区的一部分,Class文件中除了存放类的版本、字段、方法、接口等描述信息外,还有一项信息是常量池,用于存放编译阶段生成的各种字面量和符号引用,这部分内容将在类加载后进入方法区的运行时常量池中存放。

          

这篇关于关于Java虚拟机二三事(一)---Java技术体系及JVM内存结构的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1098033

相关文章

Spring Boot整合Redis注解实现增删改查功能(Redis注解使用)

《SpringBoot整合Redis注解实现增删改查功能(Redis注解使用)》文章介绍了如何使用SpringBoot整合Redis注解实现增删改查功能,包括配置、实体类、Repository、Se... 目录配置Redis连接定义实体类创建Repository接口增删改查操作示例插入数据查询数据删除数据更

Java Lettuce 客户端入门到生产的实现步骤

《JavaLettuce客户端入门到生产的实现步骤》本文主要介绍了JavaLettuce客户端入门到生产的实现步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要... 目录1 安装依赖MavenGradle2 最小化连接示例3 核心特性速览4 生产环境配置建议5 常见问题

Java使用Swing生成一个最大公约数计算器

《Java使用Swing生成一个最大公约数计算器》这篇文章主要为大家详细介绍了Java使用Swing生成一个最大公约数计算器的相关知识,文中的示例代码讲解详细,感兴趣的小伙伴可以了解一下... 目录第一步:利用欧几里得算法计算最大公约数欧几里得算法的证明情形 1:b=0情形 2:b>0完成相关代码第二步:加

Java 的ArrayList集合底层实现与最佳实践

《Java的ArrayList集合底层实现与最佳实践》本文主要介绍了Java的ArrayList集合类的核心概念、底层实现、关键成员变量、初始化机制、容量演变、扩容机制、性能分析、核心方法源码解析、... 目录1. 核心概念与底层实现1.1 ArrayList 的本质1.1.1 底层数据结构JDK 1.7

Java Map排序如何按照值按照键排序

《JavaMap排序如何按照值按照键排序》该文章主要介绍Java中三种Map(HashMap、LinkedHashMap、TreeMap)的默认排序行为及实现按键排序和按值排序的方法,每种方法结合实... 目录一、先理清 3 种 Map 的默认排序行为二、按「键」排序的实现方式1. 方式 1:用 TreeM

Java中流式并行操作parallelStream的原理和使用方法

《Java中流式并行操作parallelStream的原理和使用方法》本文详细介绍了Java中的并行流(parallelStream)的原理、正确使用方法以及在实际业务中的应用案例,并指出在使用并行流... 目录Java中流式并行操作parallelStream0. 问题的产生1. 什么是parallelS

Java中Redisson 的原理深度解析

《Java中Redisson的原理深度解析》Redisson是一个高性能的Redis客户端,它通过将Redis数据结构映射为Java对象和分布式对象,实现了在Java应用中方便地使用Redis,本文... 目录前言一、核心设计理念二、核心架构与通信层1. 基于 Netty 的异步非阻塞通信2. 编解码器三、

SpringBoot基于注解实现数据库字段回填的完整方案

《SpringBoot基于注解实现数据库字段回填的完整方案》这篇文章主要为大家详细介绍了SpringBoot如何基于注解实现数据库字段回填的相关方法,文中的示例代码讲解详细,感兴趣的小伙伴可以了解... 目录数据库表pom.XMLRelationFieldRelationFieldMapping基础的一些代

一篇文章彻底搞懂macOS如何决定java环境

《一篇文章彻底搞懂macOS如何决定java环境》MacOS作为一个功能强大的操作系统,为开发者提供了丰富的开发工具和框架,下面:本文主要介绍macOS如何决定java环境的相关资料,文中通过代码... 目录方法一:使用 which命令方法二:使用 Java_home工具(Apple 官方推荐)那问题来了,

Java HashMap的底层实现原理深度解析

《JavaHashMap的底层实现原理深度解析》HashMap基于数组+链表+红黑树结构,通过哈希算法和扩容机制优化性能,负载因子与树化阈值平衡效率,是Java开发必备的高效数据结构,本文给大家介绍... 目录一、概述:HashMap的宏观结构二、核心数据结构解析1. 数组(桶数组)2. 链表节点(Node