lua错误信息和回跟踪(Tracebacks)
来源:互联网 发布:淘宝争议处理规则 编辑:程序博客网 时间:2024/06/03 22:55
虽然你可以使用任何类型的值作为错误信息,通常情况下,我们使用字符串来描述遇到的错误。如果遇到内部错误(比如对一个非table的值使用索引下标访问)Lua将自己产生错误信息,否则Lua使用传递给error函数的参数作为错误信息。不管在什么情况下,Lua都尽可能清楚的描述问题发生的缘由。
local status, err = pcall(function () a = 'a'+1 end)
print(err)
--> stdin:1: attempt to perform arithmetic on a string value
local status, err = pcall(function () error("my error") end)
print(err)
--> stdin:1: my error
例子中错误信息给出了文件名(stdin)与行号。
函数error还可以有第二个参数,表示错误发生的层级。比如,你写了一个函数用来检查“error是否被正确调用”:
function foo (str)
if type(str) ~= "string" then
error("string expected")
end
...
end
可有人这样调用此函数:
foo({x=1})
Lua会指出发生错误的是foo而不是error,实际上,错误是调用error时产生的。为了纠正这个问题,修改前面的代码让error报告错误发生在第二级(你自己的函数是第一级)如下:
function foo (str)
if type(str) ~= "string" then
error("string expected", 2)
end
...
end
当错误发生的时候,我们常常希望了解详细的信息,而不仅是错误发生的位置。若能了解到“错误发生时的栈信息”就好了,但pcall返回错误信息时,已经释放了保存错误发生情况的栈信息。因此,若想得到tracebacks,我们必须在pcall返回以前获取。Lua提供了xpcall来实现这个功能,xpcall接受两个参数:调用函数、错误处理函数。当错误发生时,Lua会在栈释放以前调用错误处理函数,因此可以使用debug库收集错误相关信息。有两个常用的debug处理函数:debug.debug和debug.traceback,前者给出Lua的提示符,你可以自己动手察看错误发生时的情况;后者通过traceback创建更多的错误信息,也是控制台解释器用来构建错误信息的函数。你可以在任何时候调用debug.traceback获取当前运行的traceback信息:
print(debug.traceback())
- lua错误信息和回跟踪(Tracebacks)
- lua错误信息
- java/android错误信息代码跟踪
- java错误信息之代码跟踪
- Makefile文件调试跟踪打印警告错误信息
- php错误信息回显和错误日志
- unity-luaFramewrok中lua错误信息的捕获
- JMeter 日志和错误信息
- 小异常和错误信息
- oracle存储过程错误跟踪(保存错误行号,错误代码,错误信息)
- oracle存储过程错误跟踪(保存错误行号,错误代码,错误信息)
- [经验之谈]程序之中如何通过日志跟踪错误信息
- 跟踪算法(mean-shift和Camshift)
- C调lua出错,返回c层打印错误信息.
- 学习lua结合unity遇到错误信息的解决方法
- Lua知识点四 编译·运行·错误信息
- jsf消息和错误信息本地化
- HRESULT 数据类型和显示错误信息
- CAMERA驱动调试指引
- Android必备的Java知识点
- 单链表各种操作的C语言实现(一)
- MySQL学习笔记_12_Linux下C++/C连接MySQL数据库(二) --返回数据的SQL
- IO多路复用之epoll总结
- lua错误信息和回跟踪(Tracebacks)
- Iterator&Map&List&LinkedHashMap&普通for循环&增强for循环&bean
- SQL Error Code 说明
- Android Studio新建没有ActionBar的Activity
- 栈和队列的相互实现
- LeetCode Minimum Depth of Binary Tree
- linux环境变量之jdk+tomcat+maven
- MySQL学习笔记_11_Linux下C++/C连接MySQL数据库(一)
- MyBatis Invalid bound statement