”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > 改进了&#printf&#调试

改进了&#printf&#调试

发布于2024-11-03
浏览:235

“printf”调试是最常见的调试技术之一,特别受欢迎,因为大多数人在编写第一个程序时直观地学习它。

“printf”调试非常容易进行,因为您不需要任何特殊工具。当您遇到第一个错误时,甚至在您知道什么是调试器之前,自然要做的就是让您的程序逐步打印变量,以便您可以跟踪控制台中的执行。

虽然它是最基本的调试技术之一,但它也被经验丰富的开发人员广泛使用。它可以帮助您调查任何类型的问题,例如次优例程、不一致的状态、多线程问题等等。

正如我已经提到的,这种技术不需要您使用任何特殊工具,例如 IDE。但是,如果您正在使用它,它可以使您更有效地记录程序状态。

注意:本文展示了IntelliJ IDEA的功能。其他 IDE 中可能有也可能没有类似的功能。如果您使用其他工具,请考虑检查其文档以查看这些功能是否也存在。

实时模板

IntelliJ IDEA 为最常见的调试日志记录模式提供实时模板。要使用实时模板进行调试日志记录,请输入相应的缩写并按 Tab 键。 IntelliJ IDEA 将生成打印语句并将其插入游标中。

让我们看几个例子。

注册方法参数

public static BufferedImage recolor(BufferedImage in, BufferedImage mask, int newColor) {

    // escriba 'soutp' aquí, luego presione Tab

    return null;
}

生成的代码:

public static BufferedImage recolor(BufferedImage in, BufferedImage mask, int newColor) {

    System.out.println("in = "   in   ", mask = "   mask   ", newColor = "   newColor);

    return null;
}

寄存器值

public static double coolMethod(double parameter) {
    double a = Math.random();
    double b = Math.random();

    // escriba 'soutv' aquí, presione Tab y luego seleccione el valor

    return a * b * parameter;
}

生成的代码:

public static double coolMethod(double parameter) {
    double a = Math.random();
    double b = Math.random();

    System.out.println("b = "   b);

    return a * b * parameter;
}

注册方法条目

public static BufferedImage recolor(BufferedImage in, BufferedImage mask, int newColor) {

    // escriba 'soutm' aquí

    return null;
}

生成的代码:

public static BufferedImage recolor(BufferedImage in, BufferedImage mask, int newColor) {

    System.out.println("ImageUtils.recolor");

    return null;
}

记录断点

使用打印语句进行调试的缺点之一是它们引入了手动管理的开销。您无法快速打开和关闭它们,并且您绝对不想在生产中犯下运输和运行它们的错误。

因此,如果您需要记录某些内容以进行调试,我建议使用记录断点,因为它们更容易处理。

Depuración

要设置记录断点,请按住 Shift,然后单击页边距。与常规断点不同,它不会暂停程序执行,而是打印到控制台。

默认情况下,这是一条消息,表明程序已到达此行。如果您希望记录当前堆栈跟踪或自定义表达式的结果,还可以使用断点设置中 Evaluate 和 log 复选框附近的选项。

Depuración

注意:小心记录表达式。评估那些导致副作用的因素可能会成为新错误或意外行为的来源。此外,当在热代码中使用时,它们可能会显着减慢您的程序速度。

当日志断点较多时,可以在断点对话框中跟踪和管理它们(运行 | 查看断点):

Depuración

您甚至可以为他们创建自定义组:

Depuración

这将帮助您集中管理断点。例如,您可以创建与特定错误相关的组并将其保存以供以后使用。当问题消失后,您只需将其关闭即可。这样,如果问题再次出现,您不必从头开始重新创建所有内容。您只需重新打开该组即可。

频繁事件日志

对于程序执行期间大量发生的事件,单独记录每个事件可能是多余的。这不仅会导致控制台充斥着消息,而且大量的 I/O 交互也会显着减慢调试会话的速度。

Depuración

对于这些事件,使用通过次数函数可能会很有用。您可以在断点.

对话框中访问它。

Depuración

Pass count设置为特定值后,只有在每次到达n次时才会触发相应的断点,确保日志记录不会成为麻烦。

概括

无论您是插入打印语句还是设置日志断点进行调试,现代工具都具有改善调试体验的功能。通过这篇文章,我想确保您了解这些让整个过程更加愉快的小技巧。

如果您对更多与调试和分析相关的文章感兴趣,请查看我的其他一些文章:

  • Debugger.godMode() – 使用调试器破解 JVM 应用程序
  • 调试器缓慢问题排查
  • createDirectories() 有什么问题? - CPU 分析指南
  • 无断点调试
版本声明 本文转载于:https://dev.to/flounder4130/depuracion-printf-mejorada-26l1?1如有侵犯,请联系[email protected]删除
最新教程 更多>
  • 为什么我会收到MySQL错误#1089:错误的前缀密钥?
    为什么我会收到MySQL错误#1089:错误的前缀密钥?
    mySQL错误#1089:错误的前缀键错误descript [#1089-不正确的前缀键在尝试在表中创建一个prefix键时会出现。前缀键旨在索引字符串列的特定前缀长度长度,可以更快地搜索这些前缀。了解prefix keys `这将在整个Movie_ID列上创建标准主键。主密钥对于唯一识别...
    编程 发布于2025-07-15
  • Java的Map.Entry和SimpleEntry如何简化键值对管理?
    Java的Map.Entry和SimpleEntry如何简化键值对管理?
    A Comprehensive Collection for Value Pairs: Introducing Java's Map.Entry and SimpleEntryIn Java, when defining a collection where each element com...
    编程 发布于2025-07-15
  • 如何为PostgreSQL中的每个唯一标识符有效地检索最后一行?
    如何为PostgreSQL中的每个唯一标识符有效地检索最后一行?
    postgresql:为每个唯一标识符提取最后一行,在Postgresql中,您可能需要遇到与在数据库中的每个不同标识相关的信息中提取信息的情况。考虑以下数据:[ 1 2014-02-01 kjkj 在数据集中的每个唯一ID中检索最后一行的信息,您可以在操作员上使用Postgres的有效效率: ...
    编程 发布于2025-07-15
  • Java为何无法创建泛型数组?
    Java为何无法创建泛型数组?
    通用阵列创建错误 arrayList [2]; JAVA报告了“通用数组创建”错误。为什么不允许这样做?答案:Create an Auxiliary Class:public static ArrayList<myObject>[] a = new ArrayList<myO...
    编程 发布于2025-07-15
  • 如何在Java字符串中有效替换多个子字符串?
    如何在Java字符串中有效替换多个子字符串?
    在java 中有效地替换多个substring,需要在需要替换一个字符串中的多个substring的情况下,很容易求助于重复应用字符串的刺激力量。 However, this can be inefficient for large strings or when working with nu...
    编程 发布于2025-07-15
  • 如何有效地转换PHP中的时区?
    如何有效地转换PHP中的时区?
    在PHP 利用dateTime对象和functions DateTime对象及其相应的功能别名为时区转换提供方便的方法。例如: //定义用户的时区 date_default_timezone_set('欧洲/伦敦'); //创建DateTime对象 $ dateTime = ne...
    编程 发布于2025-07-15
  • 为什么PHP的DateTime :: Modify('+1个月')会产生意外的结果?
    为什么PHP的DateTime :: Modify('+1个月')会产生意外的结果?
    使用php dateTime修改月份:发现预期的行为在使用PHP的DateTime类时,添加或减去几个月可能并不总是会产生预期的结果。正如文档所警告的那样,“当心”这些操作的“不像看起来那样直观。 考虑文档中给出的示例:这是内部发生的事情: 现在在3月3日添加另一个月,因为2月在2001年只有2...
    编程 发布于2025-07-15
  • Python环境变量的访问与管理方法
    Python环境变量的访问与管理方法
    Accessing Environment Variables in PythonTo access environment variables in Python, utilize the os.environ object, which represents a mapping of envir...
    编程 发布于2025-07-15
  • 如何修复\“常规错误:2006 MySQL Server在插入数据时已经消失\”?
    如何修复\“常规错误:2006 MySQL Server在插入数据时已经消失\”?
    How to Resolve "General error: 2006 MySQL server has gone away" While Inserting RecordsIntroduction:Inserting data into a MySQL database can...
    编程 发布于2025-07-15
  • 如何在Chrome中居中选择框文本?
    如何在Chrome中居中选择框文本?
    选择框的文本对齐:局部chrome-inly-ly-ly-lyly solument 您可能希望将文本中心集中在选择框中,以获取优化的原因或提高可访问性。但是,在CSS中的选择元素中手动添加一个文本 - 对属性可能无法正常工作。初始尝试 state)</option> < op...
    编程 发布于2025-07-15
  • Java中Lambda表达式为何需要“final”或“有效final”变量?
    Java中Lambda表达式为何需要“final”或“有效final”变量?
    Lambda Expressions Require "Final" or "Effectively Final" VariablesThe error message "Variable used in lambda expression shou...
    编程 发布于2025-07-15
  • 如何使用组在MySQL中旋转数据?
    如何使用组在MySQL中旋转数据?
    在关系数据库中使用mySQL组使用mySQL组进行查询结果,在关系数据库中使用MySQL组,转移数据的数据是指重新排列的行和列的重排以增强数据可视化。在这里,我们面对一个共同的挑战:使用组的组将数据从基于行的基于列的转换为基于列。 Let's consider the following ...
    编程 发布于2025-07-15
  • 如何在无序集合中为元组实现通用哈希功能?
    如何在无序集合中为元组实现通用哈希功能?
    在未订购的集合中的元素要纠正此问题,一种方法是手动为特定元组类型定义哈希函数,例如: template template template 。 struct std :: hash { size_t operator()(std :: tuple const&tuple)const {...
    编程 发布于2025-07-15
  • 大批
    大批
    [2 数组是对象,因此它们在JS中也具有方法。 切片(开始):在新数组中提取部分数组,而无需突变原始数组。 令ARR = ['a','b','c','d','e']; // USECASE:提取直到索引作...
    编程 发布于2025-07-15
  • Python读取CSV文件UnicodeDecodeError终极解决方法
    Python读取CSV文件UnicodeDecodeError终极解决方法
    在试图使用已内置的CSV模块读取Python中时,CSV文件中的Unicode Decode Decode Decode Decode decode Error读取,您可能会遇到错误的错误:无法解码字节 在位置2-3中:截断\ uxxxxxxxx逃脱当CSV文件包含特殊字符或Unicode的路径逃...
    编程 发布于2025-07-15

免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。

Copyright© 2022 湘ICP备2022001581号-3