Lua 调试 - 检测变量值变化时的方法

使用lua调试库是否可能检测变量值何时发生了改变。类似于回调函数,它会提供详细信息,例如更改值的函数、先前的值等等。这种事情可行吗?

我读到了钩子,但我不确定钩子是否可以设置为变量。

点赞
用户102937
用户102937

你可以在 Lua 中使用元表并保持一个“代理”表,使用 __newindex 函数调用来检测对变量的添加尝试,从而在一定程度上实现这一点。

这在《Lua 程序设计》书的“跟踪表访问”一章中有所涉及:

http://www.lua.org/pil/13.4.4.html

另请参阅

http://www.gammon.com.au/forum/?id=10887

2012-08-13 20:43:14
用户1442917
用户1442917

如果你不介意使用调试器,那么一些调试器允许你设置 Watch 表达式,在表达式条件为 true 时触发。我将展示如何在 MobDebug 中实现此功能(使用 lua debug 库,但据我所知,没有直接检测变量改变的方法)。

假设我们有一个脚本 start.lua,如下所示,并希望检测 foo 获取值 2 的位置:

print("Start")
local foo = 0
for i = 1, 3 do
  local function bar()
    print("In bar")
  end
  foo = i
  print("Loop")
  bar()
end
print("End")
  1. 下载 mobdebug.lua 并为脚本提供使用(最简单的方法是将其放入脚本文件夹中)。
  2. 使用 lua -e "require('mobdebug').listen()" 命令启动服务器。
  3. 使用 lua -e "require('mobdebug').loop()" 命令启动客户端。
  4. 你将在服务器窗口中看到提示符 '>'。输入 load start.lua以加载脚本。
  5. 输入 step,然后再输入 step。你将在“暂停于文件 start.lua 第 3 行”处看到此信息。
  6. 现在查看 foo 的值。输入 eval foo,你应该会看到 0。
  7. 现在我们可以设置我们的 watch。输入 setw foo == 2。在 setw 命令后,你可以指定任何 Lua 表达式;当条件被评估为 true 时,脚本的执行将停止。
  8. 使用 "run" 命令继续执行脚本。
  9. 现在 watch 触发了,你将看到类似于“暂停于文件 start.lua 第 8 行(观察表达式 1: [foo == 2])”的消息。这意味着前面的表达式已将 foo 的值更改为 2,并且执行已停在第 8 行。你可以检查脚本和当前值(可以使用“eval”和“exec”命令在脚本环境中运行任何 Lua 代码进行评估)以查找是什么触发了更改。

此方法的好处是你不仅限于监视表值,还可以指定任何表达式。主要缺点是脚本在调试器下执行,并且在每个步骤后计算表达式,可能会非常缓慢。

2012-08-13 21:50:23