Java报错输出的信息究竟是什么?

news2024/10/4 21:54:08

Java报错输出的信息究竟是什么?


本篇会带大家了解一下java运行时报错输出的信息内容,简单学习一下虚拟机内存中Java虚拟机栈的工作方式以及栈帧中所存储的信息内容

异常信息

当你的程序运行报错时,你是否会好奇打印出来的那一大坨红色的究竟是什么?

在这里插入图片描述
首先,报错的第一行是异常的主要描述信息,那么剩下的基本都是当前线程的栈帧信息
比如上图对于异常的描述是 Access denied for user 'root'@'localhost' (using password: YES),我们的数据库访问被拒绝了,原因就是我把密码输入错误了
那么异常描述下面的信息就是栈帧信息了
什么是栈帧呢,栈帧中又包含了哪些信息?


虚拟机栈

在我们的Java虚拟机中,有一个组成部分叫做运行时数据区,它是程序执行过程中用于存储数据的内存区域,这个区域用于存储程序运行过程中的各种数据,包括对象实例、类信息、局部变量、方法调用信息等
在运行时数据区中,又有一部分是虚拟机栈,每个线程都有一个独立的虚拟机栈,当方法被调用时,会在栈中创建一个新的栈帧(Stack Frame),当方法执行完毕后,栈帧会被弹出,控制权回到调用方,所以虚拟机栈中进进出出的就是程序中的方法的栈帧

那么虚拟机栈是怎么运行的呢
这里以一段代码的运行为例子:

public class Stark {
    public static void main(String[] args) {
        FunctionA();
    }
    public static void FunctionA(){
        System.out.println("运行了A");
        FunctionB();
    }
    public static void FunctionB(){
        System.out.println("运行了B");
    }
}

当我们运行这段程序时,第一个执行的是Main方法,在Main方法中又调用执行了A方法,在A方法中又执行了B方法,那么在虚拟机栈中,要执行的方法的栈帧会进入虚拟机栈中,待方法完全执行完毕后,他的栈帧才会被弹出:
在这里插入图片描述
此时,三个方法都还没有完全结束,当B方法被调用,输出"运行了B"后,B方法的栈帧才会弹出虚拟机栈,以此类推:
在这里插入图片描述
这就是虚拟机栈的运行过程,我们也可以在IDEA中使用断点调试查看到线程的虚拟机栈,依然使用上面的代码,在B方法上打断点,点击调试运行:
在这里插入图片描述
在左下角就可以看到目前存在的线程中的栈中有哪些栈帧:
在这里插入图片描述
此时正处于B方法中,也就是上图中A方法刚刚调用的B方法,B方法还未结束时,栈中有三个方法的栈帧信息


文章开头提到,报错时会输出当前线程全部的栈帧信息,我们可以试一下
在上述代码的B方法中添加一句抛出异常的代码:

public class Stark {
    public static void main(String[] args) {
        FunctionA();
    }
    public static void FunctionA(){
        System.out.println("运行了A");
        FunctionB();
    }
    public static void FunctionB(){
        System.out.println("运行了B");
        throw new RuntimeException("出错");
    }
}

执行代码,你可以在控制台看到打印出了如下内容:
在这里插入图片描述
在报错信息的第一行显示,我们在线程mian中发生了运行时异常,异常信息:“出错”
接着,很显然下面的部分就是栈帧信息,他的打印顺序就是当前虚拟机栈中的全部栈帧依次打印


什么是栈帧

相信看到这里,你会发出疑问,什么是栈帧呢?虚拟机栈中放入的栈帧到底是个什么东西呢?
栈帧是虚拟机栈的基本存储单元,主要是由三部分组成:

  • 局部变量表:
    用于存放方法的参数和局部变量。这些变量在方法执行过程中会被频繁访问,因此将它们存储在栈帧中可以提高访问速度。局部变量表中的变量在方法调用时初始化,并在方法执行完毕后销毁
  • 操作数栈:
    用于保存计算过程中产生的中间结果和作为计算单元的操作数。操作数栈是一个后进先出(LIFO)的数据结构,与局部变量表一起支持方法的执行。
  • 帧数据:
    主要包含动态链接、方法出口、异常表等信息

局部变量表:

我们编译StarkTest类并查看他的字节码文件:

public class StarkTest {
    public static void main(String[] args) {
        int i = 0;
        int j = i + 1;
    }
}

打开方法,找到Mian方法下的LocalVariableTable就是局部变量表,表中会把方法中的参数和局部变量存放起来,索引从0开始,由于我们的main方法传入了参数args,那么表中下标为0的槽中放了args,方法中我们又声明了i,和j,那么他们会依次保存到槽中
其实局部变量表就是一个数组,每一个位置被称为一个槽,除了long类型和double类型的变量要占两个槽,其余的都只占一个槽,需要注意的是如果该方法不是静态方法而是示例方法,该方法运行时局部变量表的第一个槽会存放调用该方法的实例对象,依旧是this
在这里插入图片描述
局部变量表中存放的变量如果在其生效范围内不会在被使用,那么之后的变量或是参数就可以覆盖他的槽,以此节省空间

操作数栈

他就是一块用来存放运行时中间数据的区域,比如上边代码中int i = 0;int j = i + 1;这两行代码执行的过程,先把0放入操作数栈中,再将操作数栈中的数赋值给变量i,然后把i的值放入操作数栈中,再把1也放入操作数栈中,让操作数栈中的两个数相加,再赋值给变量j:
在这里插入图片描述

帧数据

帧数据中主要是动态链接,方法出口

  • 动态链接:
    用于维护方法调用时的符号引用转化为直接引用的信息。在Java中,每个类都有一个常量池,用于存储符号引用。当方法被调用时,JVM会通过动态链接将符号引用转化为直接引用,以便在方法执行过程中访问其他类或方法。
  • 方法出口:
    记录方法正常退出或异常退出时的处理信息。当方法执行完毕后,JVM会根据方法出口的信息将控制权返回给调用者。如果方法在执行过程中抛出异常,JVM也会根据方法出口的信息来处理异常

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2188770.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

搜索引擎相关的一段实习经历

0 前言 就是跟搜索相关的一段经历。主要工作就是建立倒排索引库相关的一些简单内容。 又翻到了以前的工作,权作纪念。 就是简单的封装cpp的库供python语言调用。 反正就是很多版本问题等等吧各种鬼问题。 我感觉这个思路可能还是待考证。 跨语言的调用我感觉还是不…

泛型编程--模板【C++提升】(特化、类属、参数包的展开、static、模板机制、重载......你想知道的全都有)

更多精彩内容..... 🎉❤️播主の主页✨😘 Stark、-CSDN博客 本文所在专栏: C系列语法知识_Stark、的博客-CSDN博客 其它专栏: 数据结构与算法_Stark、的博客-CSDN博客 C系列项目实战_Stark、的博客-CSDN博客 座右铭:梦…

Java中的while和do...while循环

while和do...while循环 while循环基本语法执行流程注意事项练习 do...while循环基本语法说明流程图练习 while循环 基本语法 循环变量初始化; while(循环条件){循环体(语句);循环变量迭代; }1)while循环也有四要素:循环变量初始…

【JNI】普通类型的基本使用

简单使用 在上一期我们介绍了JNI的基本使用,这里简单介绍一下普通类型 HelloJNI.java:这里计算两个整型数的平均值,返回值类型为double public class HelloJNI { static {System.loadLibrary("hello"); }private native String …

electron-builder 首次执行报错问题解决

假日想研究一下 react electron 的使用,结果发现首次打包疯狂报错,研究了一下之后才发现是第一次的话 electron-builder 会从外面下载依赖包到我们系统中,由于某种力量导致压缩包无法下载或者是下载过慢导致失败,要解决其实也简单…

认知战认知作战:2024年9月30日中国股市大涨背景下的认知战分析报告

认知战认知作战:2024年9月30日中国股市大涨背景下的认知战分析报告 关键词:认知战, 中国股市, 信息操纵, 心理战, 技术战, 信息监管, 投资者素养, 国际合作, 法律法规, 协同作战, 谣言澄清, 市场情绪,认知作战,新质生产力,人类命运共同体,认知战,认知域…

《Linux从小白到高手》理论篇:深入理解Linux的计划任务/定时任务

值此国庆佳节,深宅家中,闲来无事,就多写几篇博文。本篇详细深入介绍Linux的计划任务/定时计划。 Linux的计划任务 在很多时候为了自动化管理系统,我们都会用到计划任务,比如关机,重启,备份之类…

二叉树--堆

1.二叉树的顺序结构 普通的二叉树是不适合用数组来存储的,因为可能会存在大量的空间浪费。而完全二叉树更适合使用顺序结 构存储。现实中我们通常把堆(一种二叉树)使用顺序结构的数组来存储,需要注意的是这里的堆和操作系统 虚拟进程地址空间中的堆是两…

CSP-J Day 4 模拟赛补题报告

姓名:王胤皓,校区:和谐校区,考试时间: 2024 2024 2024 年 10 10 10 月 4 4 4 日 9 : 00 : 00 9:00:00 9:00:00~ 12 : 30 : 00 12:30:00 12:30:00,学号: S 07738 S07738 S07738 请关注作者的…

Windows应用开发-解析AVI视频文件

本Windows应用解析AVI视频文件,以表格的方式显示AVI文件结构。并可以将结果保存到bmp图片。下面是,使用该应用解析一部AVI电影获得的图片。 应用开发信息 定义一个INFO结构,包含两个字符串对象,一个ULONGLONG变量,和…

奔驰AMG GT50升级原厂阀门运动排气声浪效果

AMG 排气系统 声浪级别可控制的AMG高性能排气系统可带来不同凡响的听觉体验。借助可调式废气风门,按下按钮,即可按需改变车辆的声浪,体验不同音色。静谧深沉或动感澎湃,悦耳声浪,如你所愿。

Python画笔案例-076 绘制纯画笔弹球

1、绘制纯画笔弹球 通过 python 的turtle 库绘制 纯画笔弹球,如下图: 2、实现代码 绘制纯画笔弹球,以下为实现代码: """纯画笔弹球动画.py读者可以在此基础上把它修改成一个拦球游戏。步骤为,建立一个Rect类,即矩形类。然后采用按键检测,当按了键时重画…

​​Python+Matplotlib可视化简单反函数和复合函数

import numpy as np import matplotlib.pyplot as plt# 设置中文字体 plt.rcParams[font.sans-serif] [SimHei] # 用黑体显示中文 plt.rcParams[axes.unicode_minus] False # 正常显示负号# 创建图形和子图 fig, (ax1, ax2) plt.subplots(1, 2, figsize(15, 6))# 反函数示…

Line: 折线图

对北京市、天津市、上海市、重庆市的近10年人口,做出折线图,效果 参考:Line - Basic_line_chart - Document (pyecharts.org) 1、折线图模板 import pyecharts.options as opts from pyecharts.charts import Linex_data ["Mon"…

基于Springboot+Vue的中医院问诊系统的设计与实现 (含源码数据库)

1.开发环境 开发系统:Windows10/11 架构模式:MVC/前后端分离 JDK版本: Java JDK1.8 开发工具:IDEA 数据库版本: mysql5.7或8.0 数据库可视化工具: navicat 服务器: SpringBoot自带 apache tomcat 主要技术: Java,Springboot,mybatis,mysql,vue 2.视频演示地址 3.功能 系统中…

内存卡数据恢复软件大揭秘,拯救你的重要数据

我们的生活中充斥着各种各样的数据,而内存卡作为一种常见的数据存储设备,承载着我们的照片、视频、文档等重要信息。然而存储在电子设备上就有可能导致数据丢失的情况。今天我们一起来探讨内存卡数据恢复的一些工具吧。 1.福晰内存卡数据恢复 连接直达…

ros2使用roscore报错

如果你在ros2中使用roscore命令,可能会出现报错。 即使你按照下面的命令安装python3-roslaunch,还是会报错。 注意,在ROS2中,已经不需要通过roscore命令启动ROS系统了。 ROS2中,不再需要ROS1中的roscore命令来启动一个…

【Python】Arrow使用指南:轻松管理日期与时间

Arrow 是一个基于 Python 的日期与时间管理库,提供了更人性化和直观的 API 处理时间数据。与 Python 标准库中的 datetime 模块相比,Arrow 极大地简化了时间创建、转换、格式化和操作的步骤。它通过统一的接口封装了常见的时间操作,支持时区转…

[C语言]--编译和链接

文章目录 目录 文章目录 前言 一、环境介绍 二、翻译环境 1.预处理(预编译) 2.编译 3.汇编 4.链接 三、运行环境 前言 对编译和链接 进行简单的介绍 一、环境介绍 在ANSIC的任何⼀种实现中,存在两个不同的环境。 翻译环境,在这…

Python从入门到高手4.4节-算法实战之计算次大值

目录 4.4.1 四个随机数中的次大值 4.4.2 计算次大值的算法思路 4.4.3 使用循环计算次大值 4.4.4 祝祖国繁荣昌盛 4.4.1 四个随机数中的次大值 假设有四个整型变量,它们值的大小未知,该怎么计算出四个中的次大值? 次大值即第二大的数。初…