在项目开发过程中遇到一个bug,和全局table中的一个变量有关,但是这个变量在多个文件中有修改,看代码追踪这个变量具体在那个地方被修改了,结果看到晕,也没有找到问题。后来在想有什么简单的方法没有,就想到lua的元表,__index和__newindex,可以利用这个,和debug.tarceback结合使用。
具体例子:比如需要追踪data表格中的hp变量
local data = {}
local mt = {
__index = function ( table, key )
return rawget(table, key)
end,
__newindex = function ( table, key, value )
if key == "hp" then
print("this is DataGlobal __newindex key is", key, value)
print(debug.traceback())
end
rawset(table, key, value)
end
}
setmetable(data, mt)
这里要注意的是要使用rawget和rawset,绕过元表的调用,如果直接使用table[key] = value的话,会进入死循环。
其实这个模式还可以做很多事情,比如可以记录table中function的调用次数,可以给table中的变量加密。可以根据自己的需求灵活运用。
参考:http://blog.csdn.net/wangbin_jxust/article/details/12108189