## pcall 和 xpcall、debug
woo中处理错误,可以使用函数pcall(protected call)来包装需要执行的代码。
pcall接收一个函数和要传递给后者的参数,并执行,执行结果:有错误、无错误;返回值true或者或false, errorinfo。
语法格式如下
~~~
if pcall(function_name, ….) then
-- 没有错误
else
-- 一些错误
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返回时,它已经销毁了调用桟的部分内容。
woo提供了xpcall函数,xpcall接收第二个参数——一个错误处理函数,当错误发生时,woo会在调用桟展开(unwind)前调用错误处理函数,于是就可以在这个函数中使用debug库来获取关于错误的额外信息了。
debug库提供了两个通用的错误处理函数:
* debug.debug:提供一个woo提示符,让用户来检查错误的原因
* 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 使用实例 2:
## 实例
functionmyfunction()
n\=n/nil
end
functionmyerrorhandler(err)
print("ERROR:",err)
end
status\=xpcall(myfunction,myerrorhandler)
print(status)
执行以上程序会出现如下错误:
~~~
ERROR: test2.woo:2: attempt to perform arithmetic on global 'n' (a nil value)
false
~~~
- 序言
- 安装
- 可视化编辑器
- woo 命令行参数详解
- 测试用例
- 简单http服务
- 正则
- gpio控制硬件设备
- 比武不招亲
- 和php比WebServer
- woo语法
- 语法简介
- 基本语法
- woo数据类型
- woo变量
- woo循环
- woo流程控制
- woo函数
- woo运算符
- woo字符串
- 类
- 类的继承
- 模块
- 数组
- 迭代
- table
- 元表(魔术方法)
- 错误处理
- 面向对象
- woo开发必须注意事项
- 函数/模块
- 内置函数
- webServer专属函数
- 内置模块
- gd-2d绘图库
- 2D图形例子
- websockets用例
- buffer缓存
- http
- orm数据库连接
- redis-ssdb连接
- queue队列
- 其他特别函数
- sockets
- 启动线程如何
- Murphy-http Web框架
- 简介
- 全局函数
- model
- view
- controller
- 消息队列
- 全局线程锁
- 包管理器/coder wooyri package manager
- 最ok的包上榜名单
- woo栗子
- 函数传参
- 编码解码
- http模块用例
- 移动读写文件流用例
- 文件下载用例
- 数组迭代
- 进制转换
- _choose用例
- 日期时间用例
- 注明
- wop 码包|coder wooyri peogram
- 码人激励计划