Lua 错误处理
创始人
2024-05-20 13:52:16
0

Lua 错误处理

参考至菜鸟教程。

  程序运行中错误处理是必要的,在我们进行文件操作,数据转移及web service 调用过程中都会出现不可预期的错误。如果不注重错误信息的处理,就会造成信息泄露,程序无法运行等情况。

  任何程序语言中,都需要错误处理。错误类型有:

  • 语法错误
  • 运行错误

语法错误

  语法错误通常是由于对程序的组件(如运算符、表达式)使用不当引起的。一个简单的实例如下:

-- test.lua 文件
a == 2

运行结果:

效果图

  正如你所看到的,以上出现了语法错误,一个 “=” 号跟两个 “=” 号是有区别的。一个 “=” 是赋值表达式两个 “=” 是比较运算。

  另外一个实例:

for a= 1,10print(a)
end

运行结果:

效果图

  语法错误比程序运行错误更简单,运行错误无法定位具体错误,而语法错误我们可以很快的解决,如以上实例我们只要在for语句下添加 do 即可:

for a= 1,10
doprint(a)
end

运行错误

  运行错误是程序可以正常执行,但是会输出报错信息。如下实例由于参数输入错误,程序执行时报错:

function add(a,b)return a+b
endadd(10)

  当我们编译运行以下代码时,编译是可以成功的,但在运行的时候会产生如下错误:

效果图

  lua 里调用函数时,即使实参列表和形参列表不一致也能成功调用,多余的参数会被舍弃,缺少的参数会被补为 nil。

  以上报错信息是由于参数 b 被补为 nil 后,nil 参与了 + 运算。

  假如 add 函数内不是 “return a+b” 而是 “print(a,b)” 的话,结果会变成 “10 nil” 不会报错。

错误处理

  我们可以使用两个函数:assert 和 error 来处理错误。实例如下:

local function add(a,b)assert(type(a) == "number","a 不是一个数字")assert(type(b) == "number","b 不是一个数字")return a + b
endadd(10)

输出结果:

效果图

  实例中assert首先检测第一个参数,若没问题,assert不做任何事情;否则,assert以第二个参数作为错误信息抛出。

error函数

语法格式:

error(message [, level])

功能:终止正在执行的函数,并返回message的内容作为错误信息(error函数永远都不会返回)。

通常情况下,error会附加一些错误位置的信息到message头部。

Level参数指示获得错误的位置:

  • Level=1[默认]:为调用error位置(文件+行号)
  • Level=2:指出哪个调用error的函数的函数
  • Level=0:不添加错误位置信息

pcall和xpcall、debug

  Lua中处理错误,可以使用函数pcall(protected call)来包装需要执行的代码。

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

  语法格式如下:

if pcall(function_name,...) then -- 没有错误
else-- 一些错误
end

  简单实例:

print(pcall(function(i) print(i) end, 33))print(pcall(function(i)  print(i) error('error..') end, 33))function f() return false,2 
endif f() then print '1' 
else print '0' 
end

输出结果:

效果图

  pcall以一种"保护模式"来调用第一个参数,因此pcall可以捕获函数执行中的任何错误这也就意味着不会有任何错误抛出,pcall是通过返回值返回错误。而且程序的运行不会被中止,从0被输出即可看出。

  通常在错误发生时,希望获得更多的调试信息,而不只是发生错误的位置。但pcall返回时,它已经销毁了调用桟的部分内容。

  Lua提供了xpcall函数,xpcall接收第二个参数——一个错误处理函数当错误发生时,Lua会在调用桟展开(unwind)前调用错误处理函数,于是就可以在这个函数中使用debug库来获取关于错误的额外信息了。

  debug库提供了两个通用的错误处理函数:

  • debug.debug:提供一个Lua提示符,让用户来检查错误的原因。
  • debug.traceback:根据调用桟来构建一个扩展的错误消息。

实例1:

print(xpcall(function(i) print(i) error('error..') end, function() print(debug.traceback()) end, 33)
)

输出结果:

效果图

实例2:

function myfunction ()n = n/nil
endfunction myerrorhandler( err )print( "ERROR:", err )
endstatus = xpcall( myfunction, myerrorhandler )
print(status)

输出结果:

效果图

相关内容

热门资讯

监控摄像头接入GB28181平... 流程简介将监控摄像头的视频在网站和APP中直播,要解决的几个问题是:1&...
Windows10添加群晖磁盘... 在使用群晖NAS时,我们需要通过本地映射的方式把NAS映射成本地的一块磁盘使用。 通过...
protocol buffer... 目录 目录 什么是protocol buffer 1.protobuf 1.1安装  1.2使用...
在Word、WPS中插入AxM... 引言 我最近需要写一些文章,在排版时发现AxMath插入的公式竟然会导致行间距异常&#...
【PdgCntEditor】解... 一、问题背景 大部分的图书对应的PDF,目录中的页码并非PDF中直接索引的页码...
Fluent中创建监测点 1 概述某些仿真问题,需要创建监测点,用于获取空间定点的数据࿰...
educoder数据结构与算法...                                                   ...
MySQL下载和安装(Wind... 前言:刚换了一台电脑,里面所有东西都需要重新配置,习惯了所...
修复 爱普生 EPSON L4... L4151 L4153 L4156 L4158 L4163 L4165 L4166 L4168 L4...
MFC文件操作  MFC提供了一个文件操作的基类CFile,这个类提供了一个没有缓存的二进制格式的磁盘...