V8自帶了一個強大的調(diào)試器,可以從外部通過TCP協(xié)議訪問。io.js
為這個調(diào)試器內(nèi)建了一個客戶端。要使用它的話,使用debug
參數(shù)啟動io.js
;會出現(xiàn)提示符:
% iojs debug myscript.js
< debugger listening on port 5858
connecting... ok
break in /home/indutny/Code/git/indutny/myscript.js:1
1 x = 5;
2 setTimeout(function () {
3 debugger;
debug>
io.js
的調(diào)試器客戶端并未支持所有的命令,但是簡單的步進和調(diào)試都是可以的。通過在源代碼就放置debugger;
語句,你可以啟用一個斷點。
例如,假設又一個這樣的myscript.js
:
// myscript.js
x = 5;
setTimeout(function () {
debugger;
console.log("world");
}, 1000);
console.log("hello");
那么一旦你打開調(diào)試器,它會在第四行中斷。
% iojs debug myscript.js
< debugger listening on port 5858
connecting... ok
break in /home/indutny/Code/git/indutny/myscript.js:1
1 x = 5;
2 setTimeout(function () {
3 debugger;
debug> cont
< hello
break in /home/indutny/Code/git/indutny/myscript.js:3
1 x = 5;
2 setTimeout(function () {
3 debugger;
4 console.log("world");
5 }, 1000);
debug> next
break in /home/indutny/Code/git/indutny/myscript.js:4
2 setTimeout(function () {
3 debugger;
4 console.log("world");
5 }, 1000);
6 console.log("hello");
debug> repl
Press Ctrl + C to leave debug repl
> x
5
> 2+2
4
debug> next
< world
break in /home/indutny/Code/git/indutny/myscript.js:5
3 debugger;
4 console.log("world");
5 }, 1000);
6 console.log("hello");
7
debug> quit
%
repl
命令允許你遠程地執(zhí)行代碼。next
命令步進到下一行。還有一些其他的可用命令,輸入help
查看它們。
在調(diào)試代碼時,你可監(jiān)視表達式和變量的值。在每個斷點,監(jiān)視器列表上的每個表達式會被在當前上下文執(zhí)行,并且斷點的源代碼前展示。
為了開始監(jiān)視一個表達式,輸入watch("my_expression")
。watchers
打印可用的監(jiān)視器。為了移除一個監(jiān)視器,輸入unwatch("my_expression")
。
Stepping
Breakpoints
script.js
的第一行設置斷點script.js
第一行的斷點同樣也可以在一個還未載入的文件(模塊)中設置斷點:
% ./iojs debug test/fixtures/break-in-module/main.js
< debugger listening on port 5858
connecting to port 5858... ok
break in test/fixtures/break-in-module/main.js:1
1 var mod = require('./mod.js');
2 mod.hello();
3 mod.hello();
debug> setBreakpoint('mod.js', 23)
Warning: script 'mod.js' was not loaded yet.
1 var mod = require('./mod.js');
2 mod.hello();
3 mod.hello();
debug> c
break in test/fixtures/break-in-module/mod.js:23
21
22 exports.hello = function() {
23 return 'hello from module';
24 };
25
debug>
Info
repl
Execution control
Various
V8調(diào)試器可以通過 使用--debug
命令行參數(shù)打開io.js
或 向一個已存在的io.js
進程發(fā)送SIGUSR1
信號 來啟用。
一旦一個進程被設置為了調(diào)試模式,它就可以被連接到io.js
調(diào)試器??梢酝ㄟ^pid或URI來連接,語法為:
localhost:5858
)連接進程
更多建議: