学生教材网 >程序设计 > 代码分享 > Lua > 浏览文章

打印lua堆栈,包括文件名,行号,函数

来源:网络编辑:佚名时间:2015-09-28人气:

昆山视窗加盟中介,抚顺信息港,武林外传皇帝遇刺

学生教材网的小编为您介绍打印lua堆栈,包括文件名,行号,函数的具体内容:

调用lua debug.getinfo()函数获取堆栈详细信息, 打印当前所处堆栈中文件名, 行号和函数, 以及当前函数体内参数和局部变量 标签: <无>

代码片段(1) [全屏查看所有代码]

1. [代码][Lua]代码     跳至 [1] [全屏预览]

function printCallStack()
	local startLevel = 2 --0表示getinfo本身,1表示调用getinfo的函数(printCallStack),2表示调用printCallStack的函数,可以想象一个getinfo(0级)在顶的栈.
	local maxLevel = 10	--最大递归10层

	for level = startLevel, maxLevel do
		-- 打印堆栈每一层
		local info = debug.getinfo( level, "nSl") 
		if info == nil then break end
		print( string.format("[ line : %-4d]  %-20s :: %s", info.currentline, info.name or "", info.source or "" ) )

		-- 打印该层的参数与局部变量
		local index = 1 --1表示第一个参数或局部变量, 依次类推
		while true do
			local name, value = debug.getlocal( level, index )
			if name == nil then break end

			local valueType = type( value )
			local valueStr
			if valueType == 'string' then
				valueStr = value
			elseif valueType == "number" then
				valueStr = string.format("%.2f", value)
			end
			if valueStr ~= nil then
				print( string.format( "\t%s = %s\n", name, value ) )
			end
			index = index + 1
		end
	end
end

以上内容是由学生教材网的小编为您介绍的.

打印lua堆栈,包括文件名,行号,函数

调用luadebug.getinfo()函数获取堆栈详细信息,打印当前所处堆栈中文件名,行号和函数,以及当前函数体内参数和局部变量标签:<无>-->-->-->1.

lua对象序列化

将lua对象,例如string,number,table序列化成文本.

热门推荐