qt5.9.0调试如何查看变量的值_深入了解 Java 调试

Bug(俗称"八阿哥") 是软件开发绕不过的一道坎,因此调试便成了每位程序员一项必备的核心技能。调试不仅有助于理解程序的运行流程,还能改进代码质量,最终提高开发者解决问题的能力以及交付软件的品质。

本文旨在讨论 Java 调试关键技巧,同时也会介绍生产环境中调试 Java 的最佳实践。

0 调试 Java 项目

本节讨论 Java 项目调试中的常见概念与技巧,包括Breakpoint (断点)、Step filter (单步过滤器)、Drop to Frame (跳出函数到选定层)等。这些技术同样可以在复杂场景下使用。

条件断点

断点用来指定在调试过程中程序停止执行的位置。通过临时挂起执行过程,可以观察或修改字段与变量值。下面的内容虽然使用了 Eclipse进行演示,但是相关概念同样适用于其他 Java IDE。条件断点即设置成在满足特定条件时触发的断点,用来检查条件发生时程序的状态、调用堆栈及重要的变量值。

下面的示例对音乐专辑得分计算算术平均值:

044238a0dd7fce9e16546698bfbaf434.png

假设有数百张专辑,可以在循环中设置条件断点 album.getRating().score == 0。当出现专辑得分为0时,程序就会停止执行。

其他断点类型

除了上面介绍的断点类型,不同的 Java IDE 还提供了其他类型的断点:

  • 事件断点:与事件绑定,在遇到调试器能够识别的事件时触发;
  • 字段断点:给定字段或表达式的值发生变化时,字段断点将停止正在执行的程序。调试时可以指定一个字段作为观察点,表达式读取、修改时停止执行;
  • 方法断点 :进入或退出指定方法时挂起程序,用来检查特定方法的进入或退出事件;
  • 行断点:程序到达断点中设置的特定代码行时停止程序执行。

使用 Rookout 设置断点

Rookout 是一个创新的调试平台,在不停止或中断程序的情况下搜集调试数据。支持自定义断点触发条件。Rookout 提供的"断点状态"功能非常强大:在断点附近通过警告标志或 展示断点状态。

Rookout 有5种断点状态:

  • Active (紫色, 实心)
  • Pending (紫色, 空心)
  • Warning (紫色, 实心, 带三角形)
  • Error (紫色, 空心, 带三角形)
  • Disabled (灰色, 空心)

87118d7474f6668e8a6984b58edf5013.png

"断点状态" 可以在查看日志或调试信息前就能对程序运行状况有所了解。

Step Filter (单步过滤器)

Step Filter 可以在调试中指定需要跳过的 package。在调试多个 class、第三方库或框架时非常好用。在 Eclipse 中可以通过 Window Preferences >>Java Debug >>Step Filtering 配置。

Drop to frame (跳出函数到选定层)

这种技术可以在调试期间选择并重新执行程序的一部分:指定程序调用堆栈中任意帧(frame),在 Debug View 中点击 Drop-to-frame 按钮,调试器会从这里重新启动。Drop to frame 不会影响字段或现有数据,例如已写入数据库的记录。

1 远程调试

大多数 Java IDE 都支持 JVM 远程调试。设置调试参数如下:

4334e2ff77585f46bebfd7fdd4bdfdff.png

Eclipse 用户需输入主机名 (hostname) 和端口号,如下图所示:

bf6735b72ddb889cd3ed37a47c780c2a.png

2 在生产环境调试 Java

现如今开发节奏越来越快,代码发布也是如此。无论测试流程如何严格,总会有漏网之鱼。当这些漏洞遇到生产中的实际数据,产生的压力随之飙升。因此,进行系统扩展的同时解决潜在的漏洞非常关键。

下面的策略可供每个 Java 开发者参考:

  • 确定错误发生的时间;
  • 评估错误的严重程度(优先级);
  • 筛选定位导致程序出错的状态;
  • 接下来,跟踪并解决根本原因(root cause);
  • 最后,打补丁。

除了上面的五个步骤,还应当遵守下面这些生产环境最佳实践:

提高日志等级

大多数情况下,错误信息没有包含足够的上下文内容,因此调试时需要提升日志等级。完整的上下文内容可以有效地理解、定位和确定错误的根本原因。一种常见的方法,在每个线程的入口点生成 UUID。

理想情况下,可以按照以下格式设置线程名称:

e2b1bb600922ecf8a3480ac3afff0b3c.png

这样,堆栈跟踪信息会以 “threadName: pool-7-thread-22, UUID: EB85GTA, MsgType: AnalyzeGraph, MsgID: 415669, 29/03/2020 04:44” 开头,比起 “pool-7-thread-22” 这样的名字更有意义。

集中日志

在应用程序生命周期各阶段尤其是生产阶段处理错误时,应优先考虑高效的日志记录机制。把会话中所有重要事件汇集到统一的日志服务器,不但能够降低调试的难度,而且在跟踪关键产品指标时,还可以帮助监视应用程序中发生错误的情况。

检查堆栈跟踪和其他日志

调试异常时,堆栈跟踪非常有用:它能帮助确定在程序崩溃时调用了哪些函数以及调用顺序。下面的代码使用 printStack() 方法打印异常堆栈:

40fff67b351df4e493c00e5a59a79175.png

输出结果:

ec8f294b6fa939e000e8ac4d51069e99.png

复制实例

获取日志后,接下来最重要的是在复制场景(实例)。通常会创建一个与 IDE 调试类似的环境,便于分析与解决错误。

3 总结

Java 调试并不是开发者的噩梦。一点创造性思维加上合适的工具,开发者会更有信心、更加快速准确地识别、诊断和解决代码中的错误。

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

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

相关文章

(6) 如何用Apache POI操作Excel文件-----POI-3.10的一个和注解(comment)相关的另外一个bug...

如果POI-3.10往一个工作表(sheet)里面插入数据的话,需要注意了,其有一个不太被容易发现的bug。 被插入的工作表(sheet)里面的单元格没有包含任何的注解(comment)的时候,插…

python导入模块以及类_python模块的导入以及模块简介

标签: 一、模块的定义及类型 1、定义 模块就是用一堆的代码实现了一些功能的代码的集合,通常一个或者多个函数写在一个.py文件里,而如果有些功能实现起来很复杂,那么就需要创建n个.py文件,这n个.py文件的集合就是模块 …

mnist手写数字数据集_mnist手写数据集(1. 加载与可视化)

》》欢迎 点赞,留言,收藏加关注《《1. 模型构建的步骤:在构建AI模型时,一般有以下主要步骤:准备数据、数据预处理、划分数据集、配置模型、训练模型、评估优化、模型应用,如下图所示:【注意】由…

python凯撒密码实现_密码:凯撒密码及其Python实现

python凯撒密码实现Before we start let’s some basic terminology... 在开始之前,让我们先介绍一些基本术语... The art and science to achieve security by encoding messages to make them unreadable are known as Cryptography. That’s what the whole art…

qtextedit 默认文案_QT-纯代码控件-QSplitter(分裂器)

版权声明:本文为博主原创文章,遵循CC 4.0 by-sa版权协议,转载请附上原文出处链接和本声明。本文链接:https://blog.csdn.net/qq_41488943/article/details/96431379使用Qplitter实现页面的三布局分布1.新建一个无ui界面的工程&…

TYVJ P1030 乳草的入侵 Label:跳马问题

背景 USACO OCT09 6TH描述 Farmer John一直努力让他的草地充满鲜美多汁的而又健康的牧草。可惜天不从人愿&#xff0c;他在植物大战人类中败下阵来。邪恶的乳草已经在他的农场的西北部份佔领了一片立足之地。草地像往常一样&#xff0c;被分割成一个高度為Y(1 < y < 100)…

s查找mysql服务_MySQL菜鸟实录(一):MySQL服务安装实战

CentOS 7基本信息系统版本&#xff1a; CentOS 7.3 64bit系统配置&#xff1a; 4vCPUs | 8GB磁盘空间&#xff1a;[rootecs-ce5a-0001 ~]# df -hFilesystem Size Used Avail Use% Mounted on/dev/vda1 40G 17G 22G 44% /devtmpfs 3.9G 0 3.9G 0% /devtmpfs 3.9G 0 3.9G 0% /dev…

实验一 线性表的顺序存储与实现_【自考】数据结构中的线性表,期末不挂科指南,第2篇

线性表这篇博客写的是线性表相关的内容&#xff0c;包括如下部分&#xff0c;先看下有木有期待啥是线性表线性表的顺序存储线性表的基本运算在顺序表上的实现线性表的链式存储线性表的基本运算在单链表上的实现循环链表与双向循环链表Over&#xff0c;内容还蛮多的&#xff01;…

TYVJ P1012 火柴棒等式 Label:枚举

背景 NOIP2008年提高组第二题描述 给你n根火柴棍&#xff0c;你可以拼出多少个形如“ABC”的等式&#xff1f;等式中的A、B、C是用火柴棍拼出的整数&#xff08;若该数非零&#xff0c;则最高位不能是0&#xff09;。用火柴棍拼数字0-9的拼法如图所示&#xff1a;注意&#xff…

python怎么开发软件_怎么使用python进行软件开发

一、下载pyinstaller 我使用的版本为PyInstaller-2.1&#xff0c;支持python版本2.3-2.7&#xff0c;点击这里下载。 二、安装pyinstaller 下载完成后&#xff0c;解压即可。我的解压目录为D:\Python27\PyInstaller-2.1\ 三、使用pyinstaller打包.py成.exe应用程序 1.注意使用前…

28、清华大学脑机接口实验组SSVEP数据集:通过视觉触发BCI[飞一般的赶脚!]

前言&#xff1a; 哈喽&#xff0c;最近对清华大学脑机接口的数据进行了尝试&#xff0c;输入到了DL模型中&#xff0c;以下是本人对于清华BCI数据的个人见解。 数据地址&#xff1a; 清华大学脑机接口研究组 (tsinghua.edu.cn) 打开网站可以看到有很多个数据&#xff0c;官…

python Pexpect

http://www.cnblogs.com/dkblog/archive/2013/03/20/2970738.htmlhttp://www.ibm.com/developerworks/cn/linux/l-cn-pexpect2/index.htmlhttp://www.cnblogs.com/dkblog/archive/2013/03/20/2970738.htmlpython Pexpect Pexpect 是一个用来启动子程序并对其进行自动控制的纯 P…

3dmax镜像后模型线条乱了_3dMax入门教程来啦!小白赶紧收藏!

3D Studio Max&#xff0c;常简称为3d Max或3ds MAX&#xff0c;是Discreet公司开发的&#xff08;后被Autodesk公司合并&#xff09;基于PC系统的三维动画渲染和制作软件&#xff0c; 3dmax软件主要功能有建模&#xff0c;动画&#xff0c;渲染&#xff0c;特效等&#xff0c;…

如何将多个一维列表转化为二维列表_数据分析2_如何处理一维、二维数据

吞一块大饼&#xff0c;还不如切成小块吃得香常见的数据集&#xff0c;要么是数列&#xff0c;要么是表格&#xff1b;因此&#xff0c;数据分析最首要的是&#xff0c;处理一维、二维数据。主要知识点可参考如图。如需要&#xff0c;可点击以下百度网盘链接下载数据分析基础知…

关于java中锁的面试题_Java面试题-Java中的锁

1. 如何实现乐观锁(CAS)&#xff1f;如何避免ABA问题&#xff1f;答&#xff1a;1)读取内存值的方式实现了乐观锁(比如&#xff1a;SVN系统)&#xff0c;方法&#xff1a;第一&#xff0c;比较内存值和期望值&#xff1b;第二&#xff0c;替换内存值为要替换值。2)带参数版本来…

NSUserDefaults

2019独角兽企业重金招聘Python工程师标准>>> NSUserDefaults 转载于:https://my.oschina.net/18829297883/blog/737931

什么是算术运算和逻辑运算_8086微处理器的算术和逻辑运算

什么是算术运算和逻辑运算逻辑指令 (Logical Instructions) a) AND: Logical AND a)AND&#xff1a;逻辑AND Atleast one of the operant should be a register or a memory operant both the operant cannot be a memory location or immediate operant. 操作中的至少一个应该…

h5引入json_Vue中如何使用本地Json文件?

我需要将菜单配置成Json文件&#xff0c;然后再程序中引入{{menu.name}}import menuListConfig from ../../config/menu.jsonexport default {name: "Sider",data(){return {menuList:JSON.parse(JSON.stringify(menuListConfig))}}}需要如何做&#xff0c;才能v-for…

python2和python3的默认编码_python2和python3哪个版本新

Python2 还是 Python3 &#xff1f; py2.7是2.x系列的最后一个版本&#xff0c;已经停止开发&#xff0c;不再增加新功能。2020年终止支持。 所有的最新的标准库的更新改进&#xff0c;只会在3.x的版本里出现。Python3.0在2008年就发布出来&#xff0c;而2.7作为2.X的最终版本并…

使用python套用excel模板_Python自动化办公Excel-从表中批量复制粘贴数据到新表

1、模块安装 1&#xff09;cmd模式下&#xff1a; pip install -i https://pypi.tuna.tsinghua.edu.cn/simple xlrd pip install -i https://pypi.tuna.tsinghua.edu.cn/simple openpyxl 2&#xff09;如果有安装Pycharm&#xff0c;则在程序中操作如下&#xff1a; 菜单栏&…