調試lua代碼


lua沒有調試器,但是它提供了很強的調試功能(debug 庫), 所以其實一些常用的調試功能都能很方便的使用,就像使用一個命令行調試器一樣:

【例子程序】

-- debug.lua
gvar1 = 100 function foo() local var2 = 10 function bar() debug.debug() return var2 end bar() end debug.debug() foo()

 

【設置斷點】

這個比較麻煩一點,需要修改代碼加入一句:

debug.debug()

如果你要條件斷點,或者計數斷點,沒問題,直接寫代碼就是了

【開始調試】

直接運行就是:

lua debug.lua

進入斷點顯示:

[baiyanh@baiyanh-VirtualBox:~/source/arena/lua/PIL/c23-debug.lib]
$ lua debug.lua
lua_debug>

要繼續則運行cont(inue):

lua_debug> cont

【打印callstack】

lua_debug> print(debug.traceback())
stack traceback:
(debug command):1: in main chunk
[C]: in function 'debug'
debug.lua:5: in function 'bar'
debug.lua:8: in function 'foo'
debug.lua:12: in main chunk
[C]: ?

注意因為斷點是調用庫函數debug.debug才進入的,stack trace中的前2幀是debug函數引入的,需要注意。

【查看全局變量】

lua_debug> print(gvar1)
100
lua_debug> for k, v in pairs(_G) do io.write(k) io.write(" ") end
lua_debug> string xpcall package tostring print os unpack require getfenv setmetatable next assert tonumber io rawequal collectgarbage arg getmetatable bar module rawset foo gvar1 math debug pcall table newproxy type coroutine _G select gcinfo pairs rawget loadstring ipairs _VERSION dofile setfenv load error loadfile 

【查看局部變量】

局部變量不能直接訪問,需要用debug.getlocal,比如這里訪問foo函數的局部變量:

lua_debug> print(debug.getlocal(4,1))
var2    10

這里getlocal的第一個參數為幀數,我們根據debug.traceback返回的數據,知道foo對應第4幀。

【查看upvalue】

這里查看函數bar的upvalue,也就是foo里的那個局部變量

lua_debug> print(debug.getupvalue(debug.getinfo(3,"f").func, 1))
var2    10

 

這應付日常的調試應該已經足夠了(除了那些print黨:))。

當然,我們可以把這些復雜的調用事先寫成函數放在一個文件里,比如debug,然后可以:

lua debug debug.lua

這樣就更方便了。

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM