Lua在线运行

版本:

所属目录
点击了解高性能代码运行API
运行结果
教程手册
代码仓库
极速运行
终端运行
图形+终端

                        
以下是用户最新保存的代码
测试表去重 发布于:2024-11-30 14:06 Lua训练题 发布于:2024-11-22 15:04 实验室代码 发布于:2024-10-30 13:37 Lua脚本测试 发布于:2024-10-13 09:42 16*16字体显示模拟 发布于:2024-10-11 21:30 贪吃蛇游戏 发布于:2024-05-15 17:39 xLua课程 发布于:2024-05-09 12:39 unicode编码转换 发布于:2024-03-13 11:33 Lua_base64加解码 发布于:2024-03-13 14:28 table常用方法 发布于:2024-02-28 00:01 Lua 条件控制语法 发布于:2024-02-25 23:51 lua 课程 发布于:2024-02-24 17:12 啊pascal 发布于:2024-01-10 11:33 leetcode simple 发布于:2024-01-02 17:46 Lua测试 发布于:2023-11-04 16:14 包含 1、Hex转字符串 2、字符串转Hex 3、二进制与或非 发布于:2023-09-20 18:28 测试产量代码 发布于:2023-07-17 12:52 lua 基本语法测试 发布于:2023-06-25 11:11 我的 lua 测试代码 发布于:2023-06-17 17:31 LUA调用c函数的一些经验 发布于:2023-06-09 15:02 测试load 发布于:2023-07-12 16:32 lua 元表测试 发布于:2023-06-07 15:06 判断整数是不是2的倍数! 发布于:2023-05-16 16:18 每n个元素放为一组 发布于:2023-03-29 14:46 删除超出上限table测试 发布于:2024-01-07 14:52 使用lua调用redis指令,以此保证redis指令的原子性 发布于:2023-02-04 22:25 组合木板游戏 发布于:2022-11-14 19:38 n中删除k个数字 发布于:2022-11-13 15:31 最大数的输出 发布于:2022-11-09 12:48 修正版!! 发布于:2022-11-05 16:33 随便写写。 发布于:2022-11-05 16:27 lua友好数 发布于:2022-11-01 22:05 回文数lua 发布于:2022-11-01 21:06 回文数lua 发布于:2022-11-01 20:54 暂时保存。 发布于:2022-10-29 18:48 限流lua脚本 发布于:2022-10-28 09:59 鸡兔同笼啊 发布于:2022-10-17 17:37 Fibonacci 5 发布于:2022-10-11 17:27 --验证判断ProductType方法 发布于:2022-09-07 15:32 lua的闭包代码 发布于:2022-07-28 15:09 语法糖函数递归 发布于:2022-07-28 14:51 对于局部函数的使用,lua语言提供一种语法糖 发布于:2022-07-28 14:47 非全局函数 发布于:2022-07-28 14:37 函数调用函数,计算器 发布于:2022-07-27 09:55 (加减乘除)计算器 发布于:2022-07-26 17:42 九九乘法表 发布于:2022-07-26 17:14 lua的table遍历测试 发布于:2022-06-09 14:49 毕业设计代码 发布于:2022-05-14 12:56 Speed SSG 08 发布于:2021-09-09 00:14 排序算法demo 发布于:2021-08-24 11:26 [更多]
显示目录

错误处理



学习嵌入式的绝佳套件,esp8266开源小电视成品,比自己去买开发板+屏幕还要便宜,省去了焊接不当搞坏的风险。 蜂鸣版+触控升级仅36元,更强的硬件、价格全网最低。

点击购买 固件广场

Lua 错误处理

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

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

  • 语法错误
  • 运行错误

语法错误

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

-- test.lua 文件
a == 2

以上代码执行结果为:

lua: test.lua:2: syntax error near '=='

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

另外一个实例:

for a= 1,10
   print(a)
end

执行以上程序会出现如下错误:

lua: test2.lua:2: 'do' expected near 'print'

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

for a= 1,10
do
   print(a)
end

运行错误

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

function add(a,b)
   return a+b
end

add(10)

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

lua: test2.lua:2: attempt to perform arithmetic on local 'b' (a nil value)
stack traceback:
 test2.lua:2: in function 'add'
  test2.lua:5: in main chunk
    [C]: ?

以下报错信息是由于程序缺少 b 参数引起的。


错误处理

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

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

执行以上程序会出现如下错误:

lua: test.lua:3: b 不是一个数字
stack traceback:
    [C]: in function 'assert'
    test.lua:3: in local 'add'
    test.lua:6: in main chunk
    [C]: in ?

实例中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

简单实例:

> =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返回时,它已经销毁了调用桟的部分内容。

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

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

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

>=xpcall(function(i) print(i) error('error..') end, function() print(debug.traceback()) end, 33) 33 stack traceback: stdin:1: in function [C]: in function 'error' stdin:1: in function [C]: in function 'xpcall' stdin:1: in main chunk [C]: in ? false nil

xpcall 使用实例 2:

function myfunction ()
   n = n/nil
end

function myerrorhandler( err )
   print( "ERROR:", err )
end

status = xpcall( myfunction, myerrorhandler )
print( status)

执行以上程序会出现如下错误:

ERROR: test2.lua:2: attempt to perform arithmetic on global 'n' (a nil value)
false
由JSRUN为你提供的Lua在线运行、在线编译工具
        JSRUN提供的Lua 在线运行,Lua 在线运行工具,基于linux操作系统环境提供线上编译和线上运行,具有运行快速,运行结果与常用开发、生产环境保持一致的特点。
yout