Lua pcall和debug

Lua pcall和debug使用

Lua 中处理错误,可以使用函数 pcall(protected call)来包装需要执行的代码。

pcall 接收一个函数和要传递给后者的参数,并执行,执行结果:有错误、无错误;返回值 true 或者或 false, errorinfo。

pcall函数详解

语法

if pcall(function_name, ….) then -- 没有错误 else -- 一些错误 end

参数

参数 描述
function_name 函数名

案例

pcall使用

使用 pcall 处理错误,我们在命令行运行以下代码:

> =pcall(function(i) print(i) end, 33) 33 true > =pcall(function(i) print(i) error('error..') end, 33) 33 false stdin:1: error.. > function f() return false,2 end > if f() then print '1' else print '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 stack traceback: stdin:1: in function <stdin:1> [C]: in function 'error' stdin:1: in function <stdin:1> [C]: in function 'xpcall' stdin:1: in main chunk [C]: in ? false nil

xpcall使用

使用 xpcall 处理错误

#!/usr/bin/lua print("haicoder(www.haicoder.net)\n") function myfunction () n = n/nil end function myerrorhandler( err ) print( "ERROR:", err ) end status = xpcall( myfunction, myerrorhandler ) print( status)

程序运行后,控制台输出如下:

05_Lua错误处理函数.png

以上实例我们使用 xpcall 处理错误。

Lua pcall和debug总结

Lua 中处理错误,可以使用函数 pcall(protected call)来包装需要执行的代码。