Lua中的异常处理pcall、xpcall、debug使用实例(lua的表标准库)万万没想到

随心笔谈3年前发布 admin
217 0 0

文章摘要

文章主要介绍了在Lua语言中处理错误的方法。以下是简要总结: 1. **pcall函数**:使用`pcall`函数可以包装需要执行的代码,捕获执行中的任何错误。`pcall`返回的结果有两种:成功(返回`true`)或失败(返回`false`),同时返回错误信息(`errorinfo`)。 2. **错误处理**:当调用`pcall`时,如果发生错误,可以通过检查返回值来判断是否有错误。 3. **xpcall函数**:在错误发生时,`pcall`会销毁调用栈,无法获取详细调试信息。此时可以使用`xpcall`函数,它允许在错误发生时调用错误处理函数,以便获取更多的调试信息。 4. **调试信息获取**:`xpcall`结合`debug`库中的函数(如`debug.traceback`)可以构建详细的错误信息,帮助分析错误原因并解决问题。 5. **示例**:文章提供了多个示例,展示了如何正确使用`pcall`和`xpcall`函数,以及如何通过错误返回值进行逻辑判断。 总结:文章介绍了Lua中处理错误的主要方法,重点强调了`pcall`和`xpcall`函数的使用,并结合`debug`库帮助用户更深入地分析和解决问题。



如果需要在Lua中处理错误,必须使用函数pcall(protected call)来包装需要执行的代码。

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

复制代码 代码如下:

if pcall(function_name, ….) then

— no error

else

— some error

end

简单示例

复制代码 代码如下:

>=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

[C]: in function ‘error’

stdin:1: in function

[C]: in function ‘xpcall’

stdin:1: in main chunk

[C]: in ?

false        nil

您可能感兴趣的文章:Lua中简单的错误处理实例Lua函数与字符串处理简明总结Lua极简入门指南(三): loadfile和错误处理Lua读取和写入文件处理例子浅析Lua编程中的异常处理lua日志文件处理代码

© 版权声明

相关文章