Lua中的异常处理pcall、xpcall、debug使用实例
如果需要在Lua中处理错误,必须使用函数pcall(protectedcall)来包装需要执行的代码。
pcall接收一个函数和要传递个后者的参数,并执行,执行结果:有错误、无错误;返回值true或者或false,errorinfo
ifpcall(function_name,….)then --noerror else --someerror end
简单示例
>=pcall(function(i)print(i)end,33) 33 true >=pcall(function(i)print(i)error('error..')end,33) 33 false stdin:1:error..
这里注意对返回值的逻辑判断
>functionf()returnfalse,2end >iff()thenprint'1'elseprint'0'end 0
pcall以一种"保护模式"来调用第一个参数,因此pcall可以捕获函数执行中的任何错误。
通常在错误发生时,希望落得更多的调试信息,而不只是发生错误的位置。但pcall返回时,它已经销毁了调用桟的部分内容。Lua提供了xpcall函数,xpcall接收第二个参数——一个错误处理函数,当错误发生时,Lua会在调用桟展看(unwind)前调用错误处理函数,于是就可以在这个函数中使用debug库来获取关于错误的额外信息了。
debug库提供了两个通用的错误处理函数:
debug.debug:提供一个Lua提示符,让用户来价差错误的原因
debug.traceback:根据调用桟来构建一个扩展的错误消息
>=xpcall(function(i)print(i)error('error..')end,function()print(debug.traceback())end,33) 33 stacktraceback: stdin:1:infunction<stdin:1> [C]:infunction'error' stdin:1:infunction<stdin:1> [C]:infunction'xpcall' stdin:1:inmainchunk [C]:in? false nil