1.在命令行窗口中,可以使用"node debug" 命令来启用调试器,代码如下:
node debug<需要被执行的脚本文件名>接下来根据一个实例进行学习调试过程:
编写app.js文件进行调试:
console.log('hello,word') function foo(){ console.log('hello,foo') return 100; } var bar = 'This is a pen'; var http = require('http') var i = foo(); console.log(i)
1 在命令行窗口使用"node debug"命令,结果如下所示:
[root@kuber2 webproject]# node debug app.js < Debugger listening on [::]:5858 connecting to 127.0.0.1:5858 ... ok break in app.js:1 > 1 console.log('hello,word') 2 function foo(){ 3 console.log('hello,foo') debug>
在Node.js中提供了一个可以通过简单TCP协议来访问的调试器,进入调试后,首先连接调试器,如上图所示出现Debugger并后面跟有ok,说明调试器已经成功使用。"break in app.js:1" 表示脚本程序暂停的位置
2 继续执行可输入"cont"或"c",继续执行剩余的代码,结果如下所示:
[root@kuber2 webproject]# node debug app.js < Debugger listening on [::]:5858 connecting to 127.0.0.1:5858 ... ok break in app.js:1 > 1 console.log('hello,word') 2 function foo(){ 3 console.log('hello,foo') debug> c < hello,word < hello,foo < 100
3 如果不需要执行剩余的所有脚本代码,输入"next"或"n"将程序执行到下一句可执行代码前,如下所示:
[root@kuber2 webproject]# node debug app.js < Debugger listening on [::]:5858 connecting to 127.0.0.1:5858 ... ok break in app.js:1 > 1 console.log('hello,word') 2 function foo(){ 3 console.log('hello,foo') debug> n < hello,word break in app.js:6 4 return 100; 5 } > 6 var bar = 'This is a pen'; 7 var http = require('http') 8 var i = foo(); debug>
4 如果想进入函数进行调试,可以在函数被调用出输入命令"step"或"s",进入函数体,如图所示:
break in app.js:8 6 var bar = 'This is a pen'; 7 var http = require('http') > 8 var i = foo(); 9 console.log(i) 10 debug> s break in app.js:3 1 console.log('hello,word') 2 function foo(){ > 3 console.log('hello,foo') 4 return 100; 5 } debug>
5 在函数体中可以用"n",逐步进行调试,还可输入"out"或"o" 立即执行完函数内所有代码,程序将暂停到被调用函数代码后的一句代码前,如图所示:
break in app.js:3 1 console.log('hello,word') 2 function foo(){ > 3 console.log('hello,foo') 4 return 100; 5 } debug> n < hello,foo break in app.js:4 2 function foo(){ 3 console.log('hello,foo') > 4 return 100; 5 } 6 var bar = 'This is a pen'; debug> o break in app.js:9 7 var http = require('http') 8 var i = foo(); > 9 console.log(i) 10 11 }); debug>
6 利用watch可以观察变量或一些表达式的值,利用unwatch可以取消观看,具体应用如下代码所示:
break in app.js:1 > 1 console.log('hello,word') 2 function foo(){ 3 console.log('hello,foo') debug> watch("i") debug> watch("i==100") debug> n < hello,word break in app.js:6 Watchers: 0: i = undefined 1: i==100 = false 4 return 100; 5 } > 6 var bar = 'This is a pen'; 7 var http = require('http') 8 var i = foo(); debug> n break in app.js:7 Watchers: 0: i = undefined 1: i==100 = false 5 } 6 var bar = 'This is a pen'; > 7 var http = require('http') 8 var i = foo(); 9 console.log(i) debug> n break in app.js:8 Watchers: 0: i = undefined 1: i==100 = false 6 var bar = 'This is a pen'; 7 var http = require('http') > 8 var i = foo(); 9 console.log(i) 10 debug> n < hello,foo break in app.js:9 Watchers: 0: i = 100 1: i==100 = true 7 var http = require('http') 8 var i = foo(); > 9 console.log(i) 10 11 }); debug> unwatch("i") debug> unwatch("i==100") debug> n < 100 break in app.js:11 9 console.log(i) 10 >11 }); debug>
7 可以利用setBreakpoint(filename,line)或cb(filename,line),设置断点,第一个参数为设置断点的文件名,不填默认为i正在运行的文件,line为需要加断点的行号;可以利用clearBreakPoint(filename,line)或cb(filename,line)取消断点
8 使用list(n)可以显示所调试语句的前几后与后几行代码
9 使用repl可以特推出debug模式
10 使用restart可以重新开始文本调试
11 使用kill终止脚本文件调试
12 利用kill终止文本调试后可利用run重新开始
13 利用backtrace或bt可以返回运行代码的所处位置
14 利用script可以查看所有被加载的模块名称
以上这篇基于node.js之调试器详解就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持小牛知识库。
WorkerMan3.0有两种运行模式,调试模式以及daemon运行模式 运行 php start.php start 进入调试模式,这时代码中的echo、var_dump、var_export等函数打印会在终端显示。注意以php start.php start运行的WorkerMan在终端关闭时所有进程会退出。 而运行 php start.php start -d则是进入daemon模式,也就是
问题内容: 我想像rails一样调试node.js。我尝试了几种方法: Webstorm调试–在这种情况下,每次更改代码后,我都需要单击“重新运行调试” 使用chrome远程调试器的Nodemon –在这种情况下,每次由nodemon重新加载代码后,我都需要重新连接到调试器 pry.js –在这里我需要输入“ eval(pry.it)” –并没有使其更简单的选项,例如“ debug”或pry()
作为一个入门者,我是node的新手,为了解决下面的问题,我尝试了。
《Node.js 调试指南》是本人整理的从事 Node.js 开发这几年的一些调试经验和思路,希望授人以鱼也能授人以渔。
本文向大家介绍C++面试基础之static关键字详解,包括了C++面试基础之static关键字详解的使用技巧和注意事项,需要的朋友参考一下 前言 static是 c++ 的关键字,顾名思义是表示静态的含义。它在 c++ 中既可以修饰变量也可以修饰函数。那当我们使用 static 时,编译器究竟做了哪些事情呢? 早先面试中被问到 static 关键字,感觉既熟悉又陌生。熟悉是都知道如何去使用它,陌生
基于硬件模拟器实现源码级调试