## 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 ~~~