登录
首页 >  文章 >  java教程

改进了&#printf&#调试

来源:dev.to

时间:2024-08-23 21:37:07 268浏览 收藏

你在学习文章相关的知识吗?本文《改进了printf调试》,主要介绍的内容就涉及到,如果你想提升自己的开发能力,就不要错过这篇文章,大家要知道编程理论基础和实战操作都是不可或缺的哦!

最常见的调试技术之一,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;
}

记录断点

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

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

改进了

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

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

改进了

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

当日志断点变得很多时,您可以在breakpoints对话框中跟踪和管理它们(运行 | #?? #查看断点) :

改进了

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

改进了

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

频繁事件日志

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

改进了

对于这些事件,使用

pass count功能可能会很有用。您可以在对话框中访问它breakpoints.

改进了

设置

pass count为特定值后,每次到达n次才会触发对应的断点,确保日志记录不会成为麻烦。#? ?# 概括

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

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

debugger.godmode() – 使用调试器破解 jvm 应用程序
  • 调试器缓慢问题排查
  • createdirectories() 有什么问题吗? - cpu 分析指南
  • 无断点调试

今天关于《改进了printf调试》的内容介绍就到此结束,如果有什么疑问或者建议,可以在golang学习网公众号下多多回复交流;文中若有不正之处,也希望回复留言以告知!

声明:本文转载于:dev.to 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>