最常见的调试技术之一,使用“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; }
使用打印语句进行调试的缺点之一是它们引入了手动管理的开销。您无法快速打开和关闭它们,并且您绝对不想在生产中犯下运输和运行它们的错误。
因此,如果您需要记录某些内容以进行调试,我建议使用记录断点,因为它们更容易处理。
要设置记录断点,请按住 Shift,然后单击页边距。与常规断点不同,它不会暂停程序执行,而是打印到控制台。
默认情况下,这是一条消息,表明程序已到达此行。如果您希望记录当前堆栈跟踪或自定义表达式的结果,还可以使用断点设置中评估并记录复选框附近的选项。
注意:小心注册表达式。评估那些导致副作用的因素可能会成为新错误或意外行为的来源。此外,当在热代码中使用时,它们可能会显着减慢您的程序速度。
当日志断点变得很多时,您可以在断点对话框中跟踪和管理它们(运行 | 查看断点):
您甚至可以为他们创建自定义组:
这将帮助您集中管理断点。例如,您可以创建与特定错误相关的组并将其保存以供以后使用。当问题消失后,您只需将其关闭即可。这样,如果问题再次出现,您不必从头开始重新创建所有内容。您只需重新打开群组即可。
对于程序执行期间大量发生的事件,单独记录每个事件可能是多余的。这不仅会导致控制台充斥着消息,而且大量的 I/O 交互也会显着减慢调试会话的速度。
对于这些事件,使用通过计数 函数可能会很有用。您可以在断点对话框中访问它。
将传递计数设置为特定值后,只有在每次到达n次时才会触发相应的断点,确保日志记录不会成为麻烦。
无论您是插入打印语句还是设置日志断点进行调试,现代工具都具有改善调试体验的功能。通过这篇文章,我想确保您了解这些让整个过程更加愉快的小技巧。
如果您对更多与调试和分析相关的文章感兴趣,请查看我的其他一些文章:
以上是改进了printf调试的详细内容。更多信息请关注PHP中文网其他相关文章!