写 lua 的时候遇见各种前任留下的表结构,怎么快速知道结构。

2017-11-16 10:16:39 +08:00
 gdzzzyyy

前任写了一些表,不仅仅是定义的时候确定了表结构,可能在过程中会再处理一下表。怎么能快速的知道表结构,避免时间的浪费。我因为查看表结构已经 delay。。。

2412 次点击
所在节点    程序员
8 条回复
mpich
2017-11-16 10:37:13 +08:00
前任。。。
gdzzzyyy
2017-11-16 10:43:38 +08:00
@mpich 23333 不要在意这个用词。
YyYyYyy
2017-11-16 10:46:47 +08:00
手写 recursively table print 不可避
changnet
2017-11-16 10:53:06 +08:00
```lua
local function to_readable( val )
if type(val) == "string" then
return "\"" .. val .. "\""
end

return val
end

--- @param data 要打印的字符串
--- @param [max_level] table 要展开打印的计数,默认 nil 表示全部展开
--- @param [prefix] 用于在递归时传递缩进,该参数不供用户使用于
local recursion = {}
local function var_dump(data, max_level, prefix)
if type(prefix) ~= "string" then
prefix = ""
end

if type(data) ~= "table" then
print(prefix .. tostring(data))
elseif recursion[data] then
print(data,"dumplicate") --重复递归
else
recursion[data] = true
print(data)

local prefix_next = prefix .. " "
print(prefix .. "{")
for k,v in pairs(data) do
io.stdout:write(prefix_next .. tostring( to_readable(k) ) .. " = ")
if type(v) ~= "table" or (type(max_level) == "number" and max_level <= 1) then
print( to_readable(v) )
else
var_dump(v, max_level - 1, prefix_next)
end
end
print(prefix .. "}")
end
end

--[[
eg: local b = {aaa="aaa",bbb="bbb",ccc="ccc"}
]]
function vd(data, max_level)
var_dump(data, max_level or 20)
recursion = {} --释放内存
end
```
changnet
2017-11-16 10:53:54 +08:00
@changnet wocao,这回复不是 md 格式!!!!
gdzzzyyy
2017-11-16 11:01:05 +08:00
@changnet 我的意思就是遇见一个 table 就要 debug 出结构太麻烦了。感觉这也是唯一方法。
就怕在用的过程被什么地方修改了。
YyYyYyy
2017-11-16 11:22:42 +08:00
@gdzzzyyy 想要监听增删?重写元方法__newindex
想要监听修改?那你得在用这张表开始就重写__newindex 并把之后所有要加的键值全部移到一张内部代理表里。
在这种情况下还得重写__index 来修正读取。
knightdf
2017-11-16 12:02:23 +08:00
在函数输入注释上把表结构写上去,然后用 cjson 把表打出来看结构

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/406827

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX