改造Lua的debug.traceback(),让其显示栈上所有的局部变量。

本文详细解析了Lua编程语言中函数调用栈的追踪原理及实现方式,通过`functiontracebackex`函数展示了如何获取当前调用栈的信息,包括函数名、参数、局部变量等,为深入理解Lua的底层机制提供了实用的教程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

function tracebackex()
local ret = ""
local level = 2
ret = ret .. "stack traceback:\n"
while true do
   --get stack info
   local info = debug.getinfo(level, "Sln")
   if not info then break end
   if info.what == "C" then                -- C function
    ret = ret .. tostring(level) .. "\tC function\n"
   else           -- Lua function
    ret = ret .. string.format("\t[%s]:%d in function `%s`\n", info.short_src, info.currentline, info.name or "")
   end
   --get local vars
   local i = 1
   while true do
    local name, value = debug.getlocal(level, i)
    if not name then break end
    ret = ret .. "\t\t" .. name .. " =\t" .. tostringex(value, 3) .. "\n"
    i = i + 1
   end  
   level = level + 1
end
return ret
end

function tostringex(v, len)
if len == nil then len = 0 end
local pre = string.rep('\t', len)
local ret = ""
if type(v) == "table" then
   if len > 5 then return "\t{ ... }" end
   local t = ""
   for k, v1 in pairs(v) do
    t = t .. "\n\t" .. pre .. tostring(k) .. ":"
    t = t .. tostringex(v1, len + 1)
   end
   if t == "" then
    ret = ret .. pre .. "{ }\t(" .. tostring(v) .. ")"
   else
    if len > 0 then
     ret = ret .. "\t(" .. tostring(v) .. ")\n"
    end
    ret = ret .. pre .. "{" .. t .. "\n" .. pre .. "}"
   end
else
   ret = ret .. pre .. tostring(v) .. "\t(" .. type(v) .. ")"
end
return ret
end


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值