Node.js - 调试器



对于较小的Node.js代码,您可以使用 console.log() 或 console.debug() 函数间歇性地显示消息或变量的值,以手动调试代码。但是,如果Node.js代码变得更大、更复杂,则手动方法没有帮助。相反,我们可以在运行时中使用内置Node.js调试器。

考虑一个简单的Node.js代码,如下所示 (main.js) -


let marks = [34, 45, 98, 26, 51];
let total = 0;
for (let i = 0; i <= marks.length; i++) {
	 	total += marks[i];
}
var no = marks.length;
console.log(total/no);

我们预计上述程序会计算 5 名学生获得的平均分数。但是,结果不是我们预期的,当我们按如下方式运行它时 -


PS D:\nodejs> node main.js
NaN

在 JavaScript 中,NaN 表示不是数字。为了跟踪此错误,让我们使用 Node.js 调试器。相反,请使用以下命令运行程序 -


PS D:\nodejs> node inspect main.js
< Debugger listening on ws://127.0.0.1:9229/ca4aece6-308a-4979-8a32-734fe8ebbd0b
< For help, see: https://nodejs.org/en/docs/inspector
<
connecting to 127.0.0.1:9229 ... ok
< Debugger attached.
<
Break on start in a.js:1
> 1 let marks = [34, 45, 98, 26, 51];
	 2
	 3 let total = 0;
debug>

内置调试器从 localhost 的端口 9229 开始。调试器在代码的第一行中断。

我们通过告诉调试器转到程序将执行的下一行来逐步执行代码。Node.js允许以下命令使用调试器 -

命令 描述
c or cont

继续执行到下一个断点或程序结束。

n or next

移动到下一行代码。

s or step

单步执行函数。默认情况下,我们只在正在调试的块或范围内单步执行代码。

o

退出函数。单步执行函数后,当函数返回时,调试器将返回到主文件。

pause

暂停正在运行的代码。

依次按 'n' 或 'next' 遍历代码。在此循环中,每次迭代都会更改两个变量 — total 和 i。让我们为这两个变量设置观察器。


debug> watch('total')
debug> watch('i')

当您在调试提示符前按“n”时,您可以看到监视下两个变量的瞬时值。


break in main.js:6
Watchers:
	 0: total = 0
	 1: i = 0

	 4
	 5
> 6 for (let i = 0; i <= marks.length; i++) {
	 7 	 total += marks[i];
	 8 }

每次按 next 时,调试器中都会显示更改的值或总计和 I。

在最后一次迭代中,调试器的状态为 -


Watchers:
	 0: total = 254
	 1: i = 5

	 4
	 5
> 6 for (let i = 0; i <= marks.length; i++) {
	 7 	 total += marks[i];
	 8 }

下次,total 的值变为 NaN,因为循环试图超出数组。


Watchers:
	 0: total = NaN
	 1: i = 6

	 4
	 5
> 6 for (let i = 0; i <= marks.length; i++) {
	 7 	 total += marks[i];
	 8 }

因此,我们可以知道错误在于 for 循环的形成。内置调试器有助于识别错误。

您还可以在 VS Code 中启用调试Node.js代码。按 ctrl+shift+p 打开命令面板,然后选择 Attach Node.JS 进程。然后从“运行”菜单开始调试程序。它允许您在代码中执行“单步跳过”、“单步执行”和“单步执行”操作,以跟踪程序的流程。您还可以在一个或多个变量上设置监视,以便在逐步执行程序时跟踪值。