阅读其他语言: english espa?ol 中文
“printf”调试是最常见的调试技术之一,特别受欢迎,因为大多数人在编写第一个程序时直观地学习它。
“printf”调试非常容易,因为您不需要任何特殊工具。当你处理第一个 bug 时,甚至在你还不知道什么是调试器之前,你自然会想到让你的程序一步步打印变量,这样你就可以在控制台中跟踪执行。
尽管它是最基本的调试技术之一,但经验丰富的开发人员也经常使用它。它可以帮助您调查任何类型的问题,例如次优例程、不一致的状态、多线程问题等等。
正如我已经提到的,这种技术不需要您使用任何特殊工具,例如 ide。但是,如果您正在使用它,它可以让您更有效地跟踪程序状态。
点击下载“修复打印机驱动工具”;
注意:本文展示了 intellij idea 的功能。其他 ide 中可能有也可能没有类似的功能。如果您使用其他工具,请考虑检查其文档以查看这些功能是否也存在。
实时模板
intellij idea 为最常见的调试日志记录模式提供实时模板。要使用实时模板进行调试日志记录,请键入相应的命令并按 tab 键。intellij idea 将生成打印语句并将其插入到光标处。
让我们看一些例子。
注册方法参数
public static bufferedimage recolor(bufferedimage in, bufferedimage mask, int newcolor) {
// digite 'soutp' aqui, depois pressione 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();
// digite 'soutv' aqui, pressione tab e ent?o selecione o 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) {
// digite 'soutm' aqui
return null;
}
登录后复制
生成的代码:
public static BufferedImage recolor(BufferedImage in, BufferedImage mask, int newColor) {
System.out.println("ImageUtils.recolor");
return null;
}
登录后复制
注册断点
使用 print 语句进行调试的缺点之一是它们引入了手动管理的开销。您无法快速打开和关闭它们,并且您绝对不想意外妥协并在生产中运行它们。
因此,如果您需要记录某些内容以进行调试,我建议使用记录断点,因为它们更容易管理。
要设置日志记录断点,请按住 shift,然后单击选项卡。与常规断点不同,它不会暂停程序执行,而是打印到控制台。
默认情况下是一条消息,表明程序已经到达这一行。如果您希望记录当前堆栈跟踪或自定义表达式的结果,还可以使用断点设置中评估和记录复选框旁边的选项。
注意:注意注册表达式。评估那些引起副作用的因素可能会成为新错误或意外行为的来源。此外,当在热代码中使用时,它们会显着减慢您的程序速度。
当记录断点变得很多时,您可以在断点对话框中跟踪和管理它们(运行 | 查看断点):
您甚至可以为他们创建自定义组:
这将帮助您集中管理断点。例如,您可以创建与特定错误相关的组并将其保存以供以后使用。问题解决后,禁用该组。这样,如果问题再次出现,您将不必从头开始重新创建所有内容。您只需再次重新激活该群组即可。
频繁事件日志
对于程序运行期间频繁发生的事件,记录每个单独的事件可能会代价过高。这不仅会导致控制台充斥着消息,而且过多的 i/o 交互也会显着减慢调试会话的速度。
对于此类事件,使用通行证计数 功能可能会很有用。您可以在断点.对话框中访问它
一旦将pass count设置为特定值,相应的断点只会在每第n次命中时触发,确保记录不会成为干扰。
概括
无论您是插入打印语句还是设置日志断点进行调试,现代工具都具有改善调试体验的功能。通过这篇文章,我想确保您了解这些让整个过程更加愉快的小技巧。
如果您对更多与调试和分析相关的文章感兴趣,请查看我的其他一些文章:
debugger.godmode() – 使用调试器破解 jvm 应用程序
调试器缓慢故障排除
调试不活动的应用程序
createdirectories() 有什么问题吗? - cpu 配置文件指南
调试愉快!
以上就是改进了&#printf&#调试的详细内容,更多请关注php中文网其它相关文章!
91资源网站长-冰晨2024-08-27 17:15
发表在:【账号直充】爱奇艺黄金VIP会员『1个月』官方直充丨立即到账丨24小时全天秒单!不错不错,价格比官方便宜
91资源网站长-冰晨2024-08-27 16:15
发表在:2022零基础Java入门视频课程不错,学习一下