昨天遇到另外一位独立游戏开发者,所以多聊了一会,然后…然后就没有看书了。(小若:借口!借口!)
今天来聊聊错误处理吧,不过毕竟这只是前面的章节,书上的内容似乎有点一笔带过的味道。
没关系,简单更好~
1.红色警报——error
我们应该能经常看到类似以下的错误信息:
[LUA-print] LUA ERROR: [string "src/main.lua"]:108: [string "src/main.lua"]:89: attempt to index global ‘a' (a nil value)
error("你的智商不多了,赶紧休息,恢复一下吧");
然后,运行,输出如下信息:
[LUA-print] LUA ERROR: [string "src/main.lua"]:109: [string "src/main.lua"]:96: 你的智商不多了,赶紧休息,恢复一下吧
比如下面的代码:
local name = io.read(); if name ~= "笨木头" then error("你是一个非常善良有爱心的人,我很喜欢你..所以,去死吧!"); end
只要发现输入的内容不是“笨木头”,就狠狠地抛出异常。
2.偷个懒——assert
类似刚刚那种判断错误的代码,似乎有点啰嗦,于是,我们可以用assert代替形如if not then的代码。
比如上面的代码改为:
local name = io.read(); local result = assert(name == "笨木头", "你是一个非常善良有爱心的人,我很喜欢你..所以,去死吧!");
如果assert的第一个参数为不为false,则返回第一个参数的值;否则,执行error函数,输出错误信息,错误信息的内容为assert的第二个参数。
输出结果和之前是一样的~
3.捕获错误代码——pcall
如果在错误发生时,我们不希望代码停止运行,而是做一些紧急措施,那么,可以使用pcall捕获错误。
如以下代码:
function test() print(a[1]); end if pcall(test) then print("正常,呵呵"); else print("哎,函数出错了,我正在帮你处理,放心吧,等我睡醒就...不是,等你睡醒就没事了~"); end
函数test执行的时候肯定会报错的,因为并不存在a这个table。
使用pcall调用test函数,如果test不报错,则pcall返回ture,否则,返回false。
利用这个特性,我们就可以捕获异常,做一些紧急处理。
运行代码, 输出结果如下:
[LUA-print] 哎,函数出错了,我正在帮你处理,放心吧,等我睡醒就…不是,等你睡醒就没事了~ 这紧急处理的方式还挺不错的,呵呵。(小若:不错你个头啊!这和没处理有差别吗?)
function test() print(a[1]); end local status, err = pcall(test); if status then print("正常,呵呵"); else print("哎,函数出错了,我正在帮你处理,放心吧,等我睡醒就...不是,等你睡醒就没事了~"); print(err); end
pcall的第一个返回值和之前一样,true或者false。
而第二个参数则是test函数抛出的错误信息,执行代码,结果如下:
[LUA-print] 哎,函数出错了,我正在帮你处理,放心吧,等我睡醒就…不是,等你睡醒就没事了~ [LUA-print] [string "src/main.lua"]:94: attempt to index global ‘a' (a nil value)
4.结束
关于错误处理,好像没有什么好玩的东西,所以,就写这么多吧~
主要内容:语法错误,实例,实例,运行错误,错误处理,实例,pcall 和 xpcall、debug,实例,实例程序运行中错误处理是必要的,在我们进行文件操作,数据转移及web service 调用过程中都会出现不可预期的错误。如果不注重错误信息的处理,就会造成信息泄露,程序无法运行等情况。 任何程序语言中,都需要错误处理。错误类型有: 语法错误 运行错误 语法错误 语法错误通常是由于对程序的组件(如运算符、表达式)使用不当引起的。一个简单的实例如下: 以上代码执行结果为: 正如你所看到的,以上出
程序运行中错误处理是必要的,在我们进行文件操作,数据转移及web service 调用过程中都会出现不可预期的错误。如果不注重错误信息的处理,就会造成信息泄露,程序无法运行等情况。 任何程序语言中,都需要错误处理。错误类型有: 语法错误 运行错误 语法错误 语法错误通常是由于对程序的组件(如运算符、表达式)使用不当引起的。一个简单的实例如下: -- test.lua 文件 a == 2 以上代
我想知道,我怎么能设置回调光纤错误抛出。 例子: 我考虑在下次api访问时检查光纤:状态。或者创建一个光纤看门狗,如果我想要状态是有效的。这对我有用,但似乎不是最好的解决方案。
问题内容: 解析器不知道要做什么时的默认行为是将消息打印到终端,例如: 第1:23行在“}”处缺少DECIMAL 这是一个很好的信息,但是在错误的位置。我宁愿将此作为例外。 我尝试使用,但是会抛出一个没有消息的消息(由引起,也没有消息)。 有什么办法可以让我通过异常报告错误,同时又保留消息中的有用信息? 这就是我真正想要的—我通常在规则中使用动作来构建对象: 然后,当我调用解析器时,我将执行以下操
问题内容: 我有一系列要解决的承诺 我继续继续诺言链。看起来像这样 我想添加一个catch语句来处理单个promise,以防万一出错,但是当我尝试时,返回它发现的第一个错误(忽略其余的),然后我无法从其余的promise中获取数据数组(没有错误)。 我尝试做类似.. 但这并不能解决。 谢谢! - 编辑: 下面的答案完全正确,但代码由于其他原因而中断。如果有人感兴趣,这就是我最终得到的解决方案… 节
问题内容: 有没有一种方法来处理错误,比如,你可以在使用块,等等? 我已经在网上搜索过,发现的唯一选择是global变量,但是它没有按我预期的那样工作,例如,以下代码: 确实会以某种方式回滚,因为我在table1上更改的名称保留了我在此处进行测试时的旧值,但是它不会打印消息,也不会执行我在导致错误的指令之后放置的任何指令 有人可以帮我吗?您知道Sybase错误处理是如何工作的吗? 问题答案: 第一