lua 调 java_Lua 调试(Debug)

Lua 调试(Debug)

Lua 提供了 debug 库用于提供创建我们自定义调速器的功能。Lua 本身并未有内置的调速器,但很多开发者共享了他们的 Lua 调速器代码。

Lua 中 debug 库包含以下函数:

sethook ([thread,] hook, mask [, count]):

序号

方法&用途

1.

debug():进入一个用户交互模式,运行用户输入的每个字符串。使用简单的命令以及其它调试设置,用户可以检阅全局变量和局部变量,改变变量的值,计算一些表达式,等等。输入一行仅包含cont的字符串将结束这个函数,这样调用者就可以继续向下运行。

2.

getfenv(object):返回对象的环境变量。

3.

gethook(optionalthread):返回三个表示线程钩子设置的值:当前钩子函数,当前钩子掩码,当前钩子计数

4.

getinfo([thread,]f[,what]):返回关于一个函数信息的表。你可以直接提供该函数,也可以用一个数字f表示该函数。数字f表示运行在指定线程的调用栈对应层次上的函数:0层表示当前函数(getinfo自身);1层表示调用getinfo的函数(除非是尾调用,这种情况不计入栈);等等。如果f是一个比活动函数数量还大的数字,getinfo返回nil。

5.

debug.getlocal([thread,]f,local):此函数返回在栈的f层处函数的索引为local的局部变量的名字和值。这个函数不仅用于访问显式定义的局部变量,也包括形参、临时变量等。

6.

getmetatable(value):把给定索引指向的值的元表压入堆栈。如果索引无效,或是这个值没有元表,函数将返回0并且不会向栈上压任何东西。

7.

getregistry():返回注册表表,这是一个预定义出来的表,可以用来保存任何C代码想保存的Lua值。

8.

getupvalue(f,up)此函数返回函数f的第up个上值的名字和值。如果该函数没有那个上值,返回nil。以'('(开括号)打头的变量名表示没有名字的变量(去除了调试信息的代码块)。

10.

将一个函数作为钩子函数设入。字符串mask以及数字count决定了钩子将在何时调用。掩码是由下列字符组合成的字符串,每个字符有其含义:'c':每当Lua调用一个函数时,调用钩子;'r':每当Lua从一个函数内返回时,调用钩子;'l':每当Lua进入新的一行时,调用钩子。

11.

setlocal([thread,]level,local,value):这个函数将value赋给栈上第level层函数的第local个局部变量。如果没有那个变量,函数返回nil。如果level越界,抛出一个错误。

12.

setmetatable(value,table):将value的元表设为table(可以是nil)。返回value。

13.

setupvalue(f,up,value):这个函数将value设为函数f的第up个上值。如果函数没有那个上值,返回nil否则,返回该上值的名字。

14.

traceback([thread,][message[,level]]):如果message有,且不是字符串或nil,函数不做任何处理直接返回message。否则,它返回调用栈的栈回溯信息。字符串可选项message被添加在栈回溯信息的开头。数字可选项level指明从栈的哪一层开始回溯(默认为1,即调用traceback的那里)。

上表列出了我们常用的调试函数,接下来我们可以看些简单的例子:

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 库的 traceback 和 getinfo 函数, getinfo 函数用于返回函数信息的表。

另一个实例

我们经常需要调试函数的内的局部变量。我们可以使用 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

在以上实例中,计数器在每次调用时都会自增1。实例中我们使用了 getupvalue 函数查看局部变量的当前状态。我们可以设置局部变量为新值。实例中,在设置前 n 的值为 2,使用 setupvalue 函数将其设置为 10。现在我们调用函数,执行后输出为 11 而不是 3。

调试类型

命令行调试

图形界面调试

命令行调试器有:RemDebug、clidebugger、ctrace、xdbLua、LuaInterface - Debugger、Rldb、ModDebug。

图形界调试器有:SciTE、Decoda、ZeroBrane Studio、akdebugger、luaedit。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值