Java程序到CPU上执行 的步骤

2024-09-08 13:12
文章标签 java 步骤 程序 cpu 执行

本文主要是介绍Java程序到CPU上执行 的步骤,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

相信很多的小伙伴在最初学习编程的时候会容易产生一个疑惑❓,那就是编写的Java代码究竟是怎么一步一步到CPU上去执行的呢?CPU又是如何执行的呢?今天跟随小编的脚步去化解开这个疑惑❓。

在学习这个过程之前,我们需要先讲解一些与本内容相关的知识点

  • 指令

指令是指导CPU运行的命令,主要由操作码+被操作数组成。

其中操作码用来表示要做什么动作,被操作数是本条指令要操作的数据,可能是内存地址,也可能是寄存器编号等。

指令本身也是一个数字,用二进制形式保存在内存的某个区域中。

  • PC

PC是程序计数器,它的主要作用是存储下一条将要执行指令的地址。在CPU执行过程中,PC始终存储下一条指令的地址,确保指令能够按顺序执行。

  • 机器码

机器码其实是汇编语言,汇编语言就是计算机硬件能读懂的语言,不同的操作系统对应的汇编语言也是不一样的(如最后一个总结图)。

简单了解完上面这两个概念后,我们将开启正在的探索……🚩

过程大体可以分为以下几个步骤 ①编写代码->②编译源代码->③加载字节码->④链接类->⑤初始化类->⑥转换字节码为机器码->⑦CPU执行指令,解析来我们来说明每个步骤一些具体的内容

🍉:用户使用编译器完成Java代码的编写。

🍉:使用Javac对源代码进行编译,形成字节码文件(Java的跨平台离不开字节码文件的生成)。

🍉:将编译好的字节码文件加载到JVM中(若JVM事先没有启动需要先启动JVM)。

🍉:链接类需要做的有三个,第一个是验证阶段,验证阶段是为了确保字节码的准确性;第二个是准备阶段,准备阶段是为类的静态变量分配内存并设置其默认初始值;第三个阶段是解析阶段,解析阶段是为了将符号引用转化为直接引用。

🍉:在链接之后,JVM会对类进行初始化,执行静态初始化块和初始化静态变量。

🍉:JVM完成上述操作后,此时需要将字节码转换为机器码,机器码顾名思义也就是计算机可以识别出来的语言,机器码也是CPU执行的指令。

🍉:指令执行前会需要将刚刚所转化的机器码加载到内存上来,PC(程序计数器)会在计算机程序开始执行时,操作系统或者BIOS会将程序的入口点地址(即第一条指令的地址)加载到PC中。这意味着PC在开始执行程序之前就已经被设置了第一条指令的地址。然后PC会将地址传递给CPU,CPU会根据相应的地址去内存中加载对应地址的指令,随后这条指令会被存储在指令寄存器中,然后CPU会开始进行对这条指令的解析,然后去执行这条指令。当指令执行完毕的时候,PC会进入更新状态,程序计数器+1(程序计数器+1,其中这个1指的是字节数,如果是单字节,那么1变为整数1,如果是多字节则可能是其他值,),以指向下一条指令的地址(注意这里是地址,不是指令本身)。

上文中初指指向0也说明了上文中第一条执行指令的地址,当第一条执行执行完毕之后,PC+1,指向下一条指令的地址(上图中的地址是16进制转10进制形式表示的)。

❗❗❗

在执行过程中JVM会进行垃圾的回收,自动管理不再使用的对象并释放空间。

最后小编拿一个图大致的总结一下今天的内容。

内容到这里就全部讲解结束啦,希望对大家会有收获。✊✊✊

这篇关于Java程序到CPU上执行 的步骤的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

spring AMQP代码生成rabbitmq的exchange and queue教程

《springAMQP代码生成rabbitmq的exchangeandqueue教程》使用SpringAMQP代码直接创建RabbitMQexchange和queue,并确保绑定关系自动成立,简... 目录spring AMQP代码生成rabbitmq的exchange and 编程queue执行结果总结s

Go语言连接MySQL数据库执行基本的增删改查

《Go语言连接MySQL数据库执行基本的增删改查》在后端开发中,MySQL是最常用的关系型数据库之一,本文主要为大家详细介绍了如何使用Go连接MySQL数据库并执行基本的增删改查吧... 目录Go语言连接mysql数据库准备工作安装 MySQL 驱动代码实现运行结果注意事项Go语言执行基本的增删改查准备工作

Java调用Python脚本实现HelloWorld的示例详解

《Java调用Python脚本实现HelloWorld的示例详解》作为程序员,我们经常会遇到需要在Java项目中调用Python脚本的场景,下面我们来看看如何从基础到进阶,一步步实现Java与Pyth... 目录一、环境准备二、基础调用:使用 Runtime.exec()2.1 实现步骤2.2 代码解析三、

聊聊springboot中如何自定义消息转换器

《聊聊springboot中如何自定义消息转换器》SpringBoot通过HttpMessageConverter处理HTTP数据转换,支持多种媒体类型,接下来通过本文给大家介绍springboot中... 目录核心接口springboot默认提供的转换器如何自定义消息转换器Spring Boot 中的消息

Springboot项目构建时各种依赖详细介绍与依赖关系说明详解

《Springboot项目构建时各种依赖详细介绍与依赖关系说明详解》SpringBoot通过spring-boot-dependencies统一依赖版本管理,spring-boot-starter-w... 目录一、spring-boot-dependencies1.简介2. 内容概览3.核心内容结构4.

Spring Boot 整合 SSE(Server-Sent Events)实战案例(全网最全)

《SpringBoot整合SSE(Server-SentEvents)实战案例(全网最全)》本文通过实战案例讲解SpringBoot整合SSE技术,涵盖实现原理、代码配置、异常处理及前端交互,... 目录Spring Boot 整合 SSE(Server-Sent Events)1、简述SSE与其他技术的对

Spring Security 前后端分离场景下的会话并发管理

《SpringSecurity前后端分离场景下的会话并发管理》本文介绍了在前后端分离架构下实现SpringSecurity会话并发管理的问题,传统Web开发中只需简单配置sessionManage... 目录背景分析传统 web 开发中的 sessionManagement 入口ConcurrentSess

Java整合Protocol Buffers实现高效数据序列化实践

《Java整合ProtocolBuffers实现高效数据序列化实践》ProtocolBuffers是Google开发的一种语言中立、平台中立、可扩展的结构化数据序列化机制,类似于XML但更小、更快... 目录一、Protocol Buffers简介1.1 什么是Protocol Buffers1.2 Pro

Java实现本地缓存的四种方法实现与对比

《Java实现本地缓存的四种方法实现与对比》本地缓存的优点就是速度非常快,没有网络消耗,本地缓存比如caffine,guavacache这些都是比较常用的,下面我们来看看这四种缓存的具体实现吧... 目录1、HashMap2、Guava Cache3、Caffeine4、Encache本地缓存比如 caff

MyBatis-Plus 与 Spring Boot 集成原理实战示例

《MyBatis-Plus与SpringBoot集成原理实战示例》MyBatis-Plus通过自动配置与核心组件集成SpringBoot实现零配置,提供分页、逻辑删除等插件化功能,增强MyBa... 目录 一、MyBATis-Plus 简介 二、集成方式(Spring Boot)1. 引入依赖 三、核心机制