08 | LuaJIT分支和标准Lua有什么不同?
08 | LuaJIT分支和标准Lua有什么不同?
讲述:温铭
时长10:38大小8.53M
标准 Lua 和 LuaJIT 的关系
为什么选择 LuaJIT?
Lua 特别之处
1. Lua 的下标从 1 开始
2. 使用 .. 来拼接字符串
3. 只有 table 这一种数据结构
4. 默认是全局变量
LuaJIT
写在最后
赞 10
提建议
精选留言(20)
- 轨迹2019-06-12老师可以讲一下table的内部结构,把原理搞清楚,就比较容易了。 譬如这个文章:https://blog.csdn.net/wwlcsdn000/article/details/81291756 简单的就是两点: 1、两种存储,哈希和数组。 2、数组以下标覆盖到哈希,如果遇到key冲突,数组覆盖哈希的value。 我个人感觉就更好一点。展开
作者回复: 多谢补充 :)
18 - 空知2019-06-13resty -e "local t = {1, nil, name='cjf', 2} print(table.getn(t))" 3 老师 测试下这个 咋会出来3呢 不是遇见nil就停止了吗共 5 条评论7
- J.Smile2019-06-12例子讲的还是挺清楚的,希望继续讲一下具体openresty实际项目的使用场景案例5
- 逍遥2019-07-08openresty为什么要维护自己的luajit分支呢,为什么不能用luajit
作者回复: 有两个原因:一个是 LuaJIT 的作者基本处于退休状态,只修 bug,不怎么加新功能,关于 LuaJIT 的 bug,OpenResty 还是会提交给LuaJIT 官方的;第二个是新增的主要是 OpenResty 优化中遇到的 API,自己维护更容易控制版本和节奏。
4 - 一步2019-06-12上面说的 luajit 先把 字节码转为中间码爱转为 机器码 这个有个以为你,字节码不就是机器码吗? 不都是二进制的东西吗
作者回复: 这里的字节码是 LuaJIT 虚拟机执行的一种指令格式;机器码是指 CPU 可以读取的指令格式。
3 - 岁月如歌2019-07-13@空知 提出的问题 有相同的疑问? 【 resty -e "local t = {1, nil, name='cjf', 2} print(table.getn(t))" 3 老师 测试下这个 咋会出来3呢 不是遇见nil就停止了吗 】展开
作者回复: 我建议大家绕着走,把 nil 改为 ngx.null 来填充数组。不同的 lua 版本会有不同的行为,我也不太清楚。
共 5 条评论1 - 旺旺2019-06-121."在同一个 worker 内的所有协程",协程就是常说的线程吧? 2.$ resty -e 't={100}; ngx.say(t[0])' 这代码,变量定义前面需要加local才能运行。 3.“对应到上面的代码中,除了 t2 外,其他的 table 都是 array。” 这句话写反了吧,应该是“除了 t2 外,其他的 table 都是 序列。”吧1
- 林潇2022-05-20学习lua的时候遇到几个不一样的地方: 1. if必须要有end,在python和lua之间切换会很不习惯。 2. 一般一个对象访问属性是用冒号:,而不是点.,也会经常性写错。
- Leo2021-12-01我遇到的坑是在删除table的时候,用数组下标循环删除成员时,每次只删除一个还好,当删除两个连续成员的时候就会成问题 后来发现了,检测第二个元素的时候,已经因为上一个元素的删除,导致后一个符合条件的元素往前窜了一个,就想队列一样,导致元素变量索引减1,导致删不掉的bug 后来网上找了下成功经验,把队列模型改成堆栈模型,循环从小变大的规则,改成从大到小循环,即便当前索引的元素删掉,最多影响处理完的数据下标发生变化,不会影响到未处理的元素,挺有意思的。展开
- Geek_xiaoer2021-05-10请问,Lua虚拟机跟Lua解释器是一样的吗,只是表述不同?
- wedvefv2021-04-20接口文件和模块文件都需要 local print=print吗? 为了避免冲全局表找变量吗?
- 吕2020-08-16这个luajit,不是和java的hotspot一样么,just-in-time,一些是解释执行,然后对于一些热点代码,进行编译执行,这是和java hotspot虚拟机一样的机制,不知道是谁学习的谁1
- 雪粮2020-07-24对于LuaJIT VM, 可以理解为Master进程和它Fork的每个子进程中都有一个独立的LuaJIT VM吗?
- HelloTalk2019-10-20原来默认写lua 的时候,需要做二进制 位移、抑或的操作,为此自己写了一个bitop的库,发现性能更不上,后面上了 luajit,测试快了很多。
- KoALa2019-07-24lua if语句的判断方式和ruby貌似一样,nil和false才为假,其他都为真,用多了个人觉得这种判断方式更合理~~
作者回复: 主要是OpenResty 中空值的情况比较多
- 杨丁2019-07-12内容通俗易懂,赞。老师什么时候出个限流的实战吧
作者回复: 后面有专门的限流限速章节
- HelloBug2019-06-15有遇到一些让人困惑的地方是ngx.null、nil、null、“”。在网上搜索的时候,有看到说null是ngx.null的一个定义。redis的返回值的时候,经常会判断返回结果是否为空,判断的时候是和哪个值进行比较呢?关于这些个值有没有其他一些使用上的坑呢?一直以来都没有有一个明确的认识,所以和老师确认一下。
作者回复: 在 lua-resty-redis 里面,查找一个key 的时候: local res, err = red:get("dog") 如果返回值 res 是 nil,就说明函调用失败了;如果 res 是 ngx.null 就说明redis 中不存在 dog 这个key。 而在处理 cjson 的时候,又有cjson.null这个值。 所以还是要根据对应库的文档来做空值的判断和区分。 在写类似 if not res then 这样的代码的时候,要特别留意下,最好改成明确的: if res ~= nil and res ~= false then ,类似这样的,并有对应的测试案例覆盖。
1 - HelloBug2019-06-15温铭老师,你好~ 在“为什么选择luaJIT”的讲解中,讲到如果lua函数入口或者lua循环足够热,JIT编译器会从热函数的入口或者热循环的某个位置开始尝试编译。有以下几个问题请教一下老师。 1.这里的“尝试”编译的意思是并不是所有的热函数或者热循环都可以被编译,是吧? 2.另一个疑问是为什么一开始不对所有的可以被JIT编译的函数或者循环直接进行编译呢? 3.现在的JIT发现热点然后进行编译,为什么判断是否是热点时的统计,是根据一个随机的阈值,而不是一个其他,比如经过测试认为比较合理的值?展开
作者回复: LuaJIT 是会记录并统计代码的运行次数,才能知道哪些是热函数和热循环,这就是“尝试”的含义; 如果有些函数只调用了一两次,就没有编译的必要性了; 第三个问题,我的猜测可能是处于安全或者类似的考虑,就没有写死一个值,而是随机。
共 2 条评论1 - shineyyl2019-06-12$ resty -e 'local t; t={100}; ngx.say(t[1]);print(type(t[1]))' 100 number $ resty -e 'local t; t={100}; ngx.say(t[0]);print(type(t[0]))' #空 nil #nil,需要print打印出来t的数据类型展开
- 一步2019-06-12老师 文中说了 序列不应该含有 nil的,array 是可以包含 nil共 1 条评论