Lua在线运行

版本:

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

                        
以下是用户最新保存的代码
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 electrode voltage 发布于:2021-06-10 18:08 [更多]
显示目录

调试(Debug)



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

点击购买 固件广场

Lua 调试(Debug)

Lua 提供了 debug 库用于提供创建我们自定义调速器的功能。Lua 本身并未有内置的调速器,但很多开发者共享了他们的 Lua 调速器代码。

Lua 中 debug 库包含以下函数:

sethook ([thread,] hook, mask [, count]):

序号 方法 用途
1. debug(): 进入一个用户交互模式,运行用户输入的每个字符串。 使用简单的命令以及其它调试设置,用户可以检阅全局变量和局部变量, 改变变量的值,计算一些表达式,等等。
输入一行仅包含 cont 的字符串将结束这个函数, 这样调用者就可以继续向下运行。
2. getfenv(object): 返回对象的环境变量。
3. gethook(optional thread): 返回三个表示线程钩子设置的值: 当前钩子函数,当前钩子掩码,当前钩子计数
4. getinfo ([thread,] f [, what]): 返回关于一个函数信息的表。 你可以直接提供该函数, 也可以用一个数字 f 表示该函数。 数字 f 表示运行在指定线程的调用栈对应层次上的函数: 0 层表示当前函数(getinfo 自身); 1 层表示调用 getinfo 的函数 (除非是尾调用,这种情况不计入栈);等等。 如果 f 是一个比活动函数数量还大的数字, getinfo 返回 nil。
5. debug.getlocal ([thread,] f, local): 此函数返回在栈的 f 层处函数的索引为 local 的局部变量 的名字和值。 这个函数不仅用于访问显式定义的局部变量,也包括形参、临时变量等。
6. getmetatable(value): 把给定索引指向的值的元表压入堆栈。如果索引无效,或是这个值没有元表,函数将返回 0 并且不会向栈上压任何东西。
7. getregistry(): 返回注册表表,这是一个预定义出来的表, 可以用来保存任何 C 代码想保存的 Lua 值。
8. getupvalue (f, up) 此函数返回函数 f 的第 up 个上值的名字和值。 如果该函数没有那个上值,返回 nil 。
以 '(' (开括号)打头的变量名表示没有名字的变量 (去除了调试信息的代码块)。
10. 将一个函数作为钩子函数设入。 字符串 mask 以及数字 count 决定了钩子将在何时调用。 掩码是由下列字符组合成的字符串,每个字符有其含义:
'c': 每当 Lua 调用一个函数时,调用钩子;
'r': 每当 Lua 从一个函数内返回时,调用钩子;
*'l': 每当 Lua 进入新的一行时,调用钩子。
11. setlocal ([thread,] level, local, value): 这个函数将 value 赋给 栈上第 level 层函数的第 local 个局部变量。 如果没有那个变量,函数返回 nil 。 如果 level 越界,抛出一个错误。
12. setmetatable (value, table): 将 value 的元表设为 table (可以是 nil)。 返回 value。
13. setupvalue (f, up, value): 这个函数将 value 设为函数 f 的第 up 个上值。 如果函数没有那个上值,返回 nil 否则,返回该上值的名字。
14. traceback ([thread,] [message [, level]]): 如果 message 有,且不是字符串或 nil, 函数不做任何处理直接返回 message。 否则,它返回调用栈的栈回溯信息。 字符串可选项 message 被添加在栈回溯信息的开头。 数字可选项 level 指明从栈的哪一层开始回溯 (默认为 1 ,即调用 traceback 的那里)。

上表列出了我们常用的调试函数,接下来我们可以看些简单的例子:

function myfunction ()
print(debug.traceback("Stack trace"))
print(debug.getinfo(1))
print("Stack trace end")
    return 10
end
myfunction ()
print(debug.getinfo(1))

执行以上代码输出结果为:

Stack trace
stack traceback:
   test2.lua:2: in function 'myfunction'
   test2.lua:8: in main chunk
    [C]: ?
table: 0054C6C8
Stack trace end

在以实例中,我们使用到了 debug 库的 traceback 和 getinfo 函数, getinfo 函数用于返回函数信息的表。

另一个实例

我们经常需要调试函数的内的局部变量。我们可以使用 getupvalue 函数来设置这些局部变量。实例如下:

function newCounter ()
  local n = 0
  local k = 0
  return function ()
    k = n
    n = n + 1
    return n
    end
end

counter = newCounter ()
print(counter())
print(counter())

local i = 1

repeat
  name, val = debug.getupvalue(counter, i)
  if name then
    print ("index", i, name, "=", val)
    if(name == "n") then
        debug.setupvalue (counter,2,10)
   end
    i = i + 1
  end -- if
until not name

print(counter())

执行以上代码输出结果为:

1
2
index   1   k   =   1
index    2   n   =   2
11

在以上实例中,计数器在每次调用时都会自增1。实例中我们使用了 getupvalue 函数查看局部变量的当前状态。我们可以设置局部变量为新值。实例中,在设置前 n 的值为 2,使用 setupvalue 函数将其设置为 10。现在我们调用函数,执行后输出为 11 而不是 3。


调试类型

  • 命令行调试
  • 图形界面调试

命令行调试器有:RemDebug、clidebugger、ctrace、xdbLua、LuaInterface - Debugger、Rldb、ModDebug。

图形界调试器有:SciTE、Decoda、ZeroBrane Studio、akdebugger、luaedit。

由JSRUN为你提供的Lua在线运行、在线编译工具
        JSRUN提供的Lua 在线运行,Lua 在线运行工具,基于linux操作系统环境提供线上编译和线上运行,具有运行快速,运行结果与常用开发、生产环境保持一致的特点。
yout