发布于 2015-07-26 14:38:46 | 703 次阅读 | 评论: 0 | 来源: 网络整理
Lua提供了一个调试库,它提供了所有的基本功能,创造自己的调试器。即便如此,也没有内置的Lua调试器,Lua为开发者创建很多调试器是开源。
调试Lua库中可用的功能列于下表连同它的用途。
S.N. | 方法及用途 |
---|---|
1. | debug(): 进入调试,直到我们输入只在一行中,然后按回车这仍然是积极的互动模式。用户可以在使用其他功能,此模式下检查变量。 |
2. | getfenv(object): 返回对象的环境。 |
3. | gethook(optional thread): 返回该线程的当前钩设置,三个值:当前钩子函数,当前钩模,并且当前钩计数。 |
4. | getinfo(optional thread, function or stack level, optional flag): 返 回有关功能的信息表。可以直接给该函数,或者可以给一个号码作为函数的值,这意味着该函数在给定线程的调用堆栈的水平仪功能运行:0级是当前功能(程序 getinfo本身); 1级是所谓getInfo函数等等。如果函数比当前功能的数大一些,然后getinfo返回nil。 |
5. | getlocal(optional thread, stack level, local index): 返回名称和局部变量的索引为局部位于堆栈级函数的值。返回nil,如果有指定索引没有局部变量,并且当使用的级别超出范围称为引发错误。 |
6. | getmetatable(value): 返回给定对象或零nil元表,如果它没有一个元表。 |
7. | getregistry(): 返回注册表,预先定义的表格,可用于通过任何C代码来存储任何Lua的值,它需要存储。 |
8. | getupvalue(function, upvalue index): 此函数返回名称和p值与函数func索引上升的值。该函数返回零,如果存在折射率给定upvalue的值。 |
9. | setfenv(function or thread or userdata, environment table): 设置给定对象与给定表中的环境,返回Object。 |
10. | sethook(optional thread, hook function, hook mask string with "c" and/or "r" and/or "l", optional instruction count): 设置给定函数的挂钩。该字符串面具和数量计数描述时挂钩会被调用。在这里c, r 和l 被Lua每次调用,分别进入函数每一行代码。 |
11. | setlocal(optional thread, stack level, local index, value): 指定值以与索引本地位于堆栈级别函数的局部变量。函数返回零,如果存在与给定的索引没有局部变量,而当具有级别超出范围称为引发错误。否则,它返回局部变量的名称。 |
12. | setmetatable(value, metatable): 设置元表为给定对象与给定表(可以是零)。 |
13. | setupvalue(function, upvalue index, value): 此函数分配的值与函数func索引组成的upvalue。该函数返回零,如果存在与没有upvalue给定的折射率。否则,它返回upvalue的名字。 |
14. | traceback(optional thread, optional message string, optional level argument): 建立一个回溯扩展错误信息。 |
上面列表中的Lua调试功能的完整列表,我们经常使用,使用上述功能,并提供了更方便的调试库。使用这些函数和创建自己的调试器是相当复杂,不是最好的选择的。无论如何,我们将看到使用简单的调试功能的例子。
function myfunction ()
print(debug.traceback("Stack trace"))
print(debug.getinfo(1))
print("Stack trace end")
return 10
end
myfunction ()
print(debug.getinfo(1))
当我们运行上面的程序,会得到堆栈跟踪信息,如下图所示。
Stack trace
stack traceback:
test2.lua:2: in function 'myfunction'
test2.lua:8: in main chunk
[C]: ?
table: 0054C6C8
Stack trace end
在上面的示例程序中,堆栈跟踪是通过使用调试库中可用debug.trace功能打印。debug.getinfo得到函数的当前表。
我们经常会需要知道一个函数的局部变量而进行调试。为此可以使用setupvalue设置并使用getupvalue获取这些局部变量、。一个简单的例子对本如下所示。
function newCounter ()
local n = 0
local k = 0
return function ()
k = n
n = n + 1
return n
end
end
counter = newCounter ()
print(counter())
print(counter())
local i = 1
repeat
name, val = debug.getupvalue(counter, i)
if name then
print ("index", i, name, "=", val)
if(name == "n") then
debug.setupvalue (counter,2,10)
end
i = i + 1
end -- if
until not name
print(counter())
当我们运行上面的程序,会得到下面的输出。
1
2
index 1 k = 1
index 2 n = 2
11
在这个例子中,每次计数器更新当它被调用。可以使用getupvalue函数获取局部变量的当前状态。然后将局部变量的设置新值。这里,n设定为2在操作被调用之前。使用setupvalue函数更新为10,当调用计数器功能,它会返回11,而不是3。
命令行调试
图形化调试
命令行调试是使用命令行用命令和打印报表进行调试的调试类型。有这几个下面列出许多Lua可用的命令行调试器。
RemDebug: RemDebug是一个远程调试器在Lua5.0和5.1。它可以远程控制另一个Lua程序执行,设置断点和检查程序的当前状态。 RemDebug也可以调试CGILua脚本。
clidebugger: lua5.1的一个简单命令行界面调试程序用纯Lua编写。它不依赖于任何其他比标准的Lua5.1库。它是从RemDebug启发,但不具有其远端设备。
ctrace: 一种工具,跟踪Lua的API调用。
xdbLua: Windows平台的一个简单Lua命令行调试器。
LuaInterface - Debugger: 本项目为扩展LuaInterface调试器。它提出了建立在Lua调试接口到一个更高的水平。与调试器的交互是通过事件和方法调用完成。
Rldb: 这是通过套接字的远程LUA调试器,适用于Windows和Linux。它可以给你比任何现有的更多的功能。
ModDebug: 这使得可以远程控制其它Lua程序的执行,设置断点,并检查程序的当前状态。
图形化调试提供有IDE提供了各种状态,如变量值,堆栈跟踪信息和其他相关信息的可视化调试。有一种视觉表示,一步执行了断点的帮助下步控制,步入,跳过和其他按钮在IDE中。
有图形化Lua调试器的数量,它包括以下内容。
SciTE: 默认Windows IDE中的Lua提供了多种调试工具,如断点,一步,一步进入,跳过,查看变量等。
Decoda: 这是一个支持图形化调试器远程调试。
ZeroBrane Studio: Lua的IDE集成了远程调试器,堆栈视图,表视图,远程控制台,静态分析器等。工程与LuaJIT,Love2d,Moai,和其他的Lua引擎。 在Windows,OSX和Linux并且开源。
akdebugger: Lua的Eclipse插件-调试器和编辑器。
luaedit: 此功能远程调试,本地调试,语法高亮,自动完成建议列表,参数命题引擎,推进断点管理(包括断点空调系统和命中数),函数列表,全局变量和局部变量列表,查看,解决问题为导向的管理