使用节点检查时未定义预期的变量吗?

时间:2018-09-22 23:46:15

标签: javascript node.js debugging

我正在尝试使自己熟悉使用node inspect命令进行调试。我已经写成简单的脚本use_debugger.js来定义函数并调用它:

function count(nums, maxes) {
  debugger;
  return maxes;
}

count([1, 2, 3], [4, 5]);

当我进入调试器时,我期望nums被定义并具有值[1, 2, 3]。但是,如果我运行node inspect use_debugger.js,然后在REPL中键入cnums,则会发现它没有定义:

Kurts-MacBook-Pro:Scratch kurtpeek$ node --inspect-brk use_debugger.js
Debugger listening on ws://127.0.0.1:9229/7adfaada-c939-44a3-9150-6d1326b8c7d0
For help, see: https://nodejs.org/en/docs/inspector
^C
Kurts-MacBook-Pro:Scratch kurtpeek$ node inspect use_debugger.js
< Debugger listening on ws://127.0.0.1:9229/54fb6a12-82c8-4454-8307-6d120b0c26e8
< For help, see: https://nodejs.org/en/docs/inspector
< Debugger attached.
Break on start in use_debugger.js:1
> 1 (function (exports, require, module, __filename, __dirname) { function count(nums, maxes) {
  2   debugger;
  3   return maxes;
debug> c
break in use_debugger.js:2
  1 (function (exports, require, module, __filename, __dirname) { function count(nums, maxes) {
> 2   debugger;
  3   return maxes;
  4 }
debug> maxes
repl:1
maxes
^

ReferenceError: maxes is not defined
    at repl:1:1
    at Script.runInContext (vm.js:101:20)
    at Object.runInContext (vm.js:279:6)
    at REPLServer.controlEval (internal/deps/node-inspect/lib/internal/inspect_repl.js:521:25)
    at bound (domain.js:396:14)
    at REPLServer.runBound [as eval] (domain.js:409:12)
    at REPLServer.onLine (repl.js:621:10)
    at REPLServer.emit (events.js:182:13)
    at REPLServer.EventEmitter.emit (domain.js:442:20)
    at REPLServer.Interface._onLine (readline.js:290:10)
debug> 

我应该不能在函数范围numsmaxes中“访问”变量吗?

更新

要进一步记录estus'的答案,exec maxes命令对我有用:

debug> exec maxes
[ 4, 5 ]

https://nodejs.org/api/debugger.html#debugger_information中所述,exec expr命令在调试脚本的上下文中执行表达式。

1 个答案:

答案 0 :(得分:2)

JSONObject obj = new JSONObject(" .... ");
JSONArray arr = obj.getJSONArray("multimedia");
JSONObject firstMultimedia = null;
if (arr.length() > 0){
firstMultimedia = arr.getJSONObject(0);
}

在REPL范围而不是maxes 函数范围内评估maxes

the documentation中所述:

  

repl-打开调试器的repl以在调试脚本的上下文中进行评估

     

exec expr-在调试脚本的上下文中执行表达式

要在调试范围内评估count,应为:

maxes

或者:

repl
maxes