Lua可以被C/C++ 代码调用,反过来也可以调用C/C++的函数,这使得Lua被广泛应用。Lua由标准C编写而成,代码简洁优美,几乎在所有操作系统和平台上都可以编译,运行。Lua在目前解释型脚本引擎中,速度是最快的,这决定了Lua嵌入式脚本的最佳选择。文章列举lua使用中遇到的小问题,做个汇总。
if判断
lua把 nil 和false 视为“假”,其他都为“真”
local变量声明
local var1=1,var2
以上 ,var1和var2的作用域不同,var1是所在作用域的变量,var2可能是全局变量。实际上述命令解释后为 var1 取 "1,var2" 组成的值第一个值,类似 local var1 = ...
正确的写法是:
local var1, var2=1
table是否为空
if a == {} then
结果是false,这是一个逻辑错误,实际比较table a的内存地址和一个匿名table的是否相同
正确的写法是:
if next(a) == nil then
多个变量赋值
name,name = 1,2
那name等于多少呢?
实际上name值为1,可以写个小例子 a,b = 2,3,4打印汇编码就可以看到了。 方法:luac -l test.lua
table的key规则
t[name]与t["name"], t.name
第一种和后两种是不同的,第一种会根据取name的值做key,后两种以 "name"做key。这种情况还有:
t = {[name] = 1}
t = {name = 1}
t = {["name"] = 1}
table的长度
取得 table 长度最常用的做法是 #table,如下:
> t = {1,2,3}
> #t
3
但 # 操作符也是有局限的
> t = { 10, n = 20, 30, 40 }
> #t
3
实际上,#操作符取到的是 table内部数组空间的大小
> t = {}
> t[1] =1
> t[2] =1
> #t
2
> t[4] =1
> #t
4
另外,通过把元素设 nil 无法改变 #table 的结果(除非是数组最后一个元素);而 table.remove 则可以立即更新 #table 的结果
> t ={1,2,3}
> t[1]=nil
> #t
3
> table.remove(t,1)
nil
> #t
2
所以,获取table长度,在不确定元素类型(或连续性)时使用 for in pairs,也就是遍历table
table引用问题
将一个table复制给另外一个table,修改这个新的table值会影响原来的table,但通过clone可以改变这一行为。
-- 下面的代码,t2 是 t1 的引用,修改 t2 的属性时,t1 的内容也会发生变化
local t1 = {a = 1, b = 2}
local t2 = t1
t2.b = 3 -- t1 = {a = 1, b = 3} <-- t1.b 发生变化
-- clone() 返回 t1 的副本,修改 t2 不会影响 t1
local t1 = {a = 1, b = 2}
local t2 = clone(t1)
t2.b = 3 -- t1 = {a = 1, b = 2} <-- t1.b 不受影响
clone不是原生的lua内置函数,这里也补充这个函数:
function clone(object)
local lookup_table = {}
local function _copy(object)
if type(object) ~= "table" then
return object
elseif lookup_table[object] then
return lookup_table[object]
end
local new_table = {}
lookup_table[object] = new_table
for index, value in pairs(object) do
new_table[_copy(index)] = _copy(value)
end
return setmetatable(new_table, getmetatable(object))
end
return _copy(object)
end
函数返回值
> function f123() return 1, 2, 3 end
> function f456() return 4, 5, 6 end
> print(f123(), f456())
1 4 5 6
> print(f456(), f123())
4 1 2 3
> print(f456())
4 5 6
> print(f456(),1)
4 1
如果函数不是处于列的最后一个,只返回一个值
浮点数问题
> math.floor(0.57*100)
56
这是浮点数都会有的精度丢失问题,lua也有这个问题。再看下整数与浮点数的比较:
> =10==10.00000000000000000
true
> =10==10.00000000000000001
true
> =10==10.00000000000000000
true
> =10==9.999999999999999999
true
如何比较两个浮点数是否相等?这里介绍一个方法:
function float_equal(x,v)
local EPSILON = 0.000001
return ((v - EPSILON) < x) and (x <( v + EPSILON))
end
print(float_equal(0.9999999, 1.0000001))
其中,EPSILON就是你允许的精度差
lua整数
在lua5.3之前,lua没有整数,都是用浮点数表示的,最早的版本用float,然后在3.1之后改用double。直到lua5.3,lua才引入了整数,默认是64bit。既然之前的lua版本用到的是浮点数,那必然有精度问题,浮点数需要一部分位来表示指数,double的有效数字是53bit,能表达的最大的有效整数是6755399441055744,而lua5.3能表达的最大整数是9223372036854775807
冒号语法
冒号语法可以用来定义函数, 这样的话,函数会有一个隐式的形参 self。
写法如下:
function t:f (params) body end
冒号语法实际上是一种语法糖,等效于:
t.f = function (self, params) body end
这里补充例子说明下:
local t={a=123}
function t.f1(self, p)
print(self.a, p)
end
function t:f2(p)
print(self.a, p)
end
t:f1(1)
t.f1(t,1)
t:f2(1)
t.f2(t,1)
以上几个结果都是123 1
这里,通过冒号方式调用函数不需要加入self参数,而点号则需要。
2016/01/19 标题“总结lua使用中遇到的小问题”改成“用lua这么久,你真的了解吗”
2016/01/19 补充lua取table长度的说明
2015/10/20 补充lua冒号语法的说明
2015/10/8 补充lua整数的有效数字说明
参考:http://blog.csdn.net/mycwq/article/details/48765303
分享到:
相关推荐
**lzmq:Lua绑定到ZeroMQ** lzmq是将开源的高效消息传递库ZeroMQ(又称ØMQ或零MQ)与脚本语言Lua紧密结合的绑定库。...通过使用lzmq,你可以轻松地在Lua中实现复杂的网络通信方案,提升软件的可扩展性和可靠性。
开发者可以通过阅读源代码或项目文档来了解如何使用这些功能。 9. **错误处理与调试**:在实际使用中,Joynet 应该提供了错误处理机制,帮助开发者在遇到问题时快速定位和解决。调试工具和日志记录也是必不可少的,...
另外要了解的一点是,XLua不像ToLua那样必须导出脚本才能在Lua中使用,XLua遇到没有导出的脚本会自动用反射去访问,所以对于XLua来说,脚本导出只是可以提高性能,另外就是安全性,避免代码裁剪导致IOS上出现jit错误...
在`pico8-table-string-master`文件中,可能包含了源代码、示例和文档,帮助开发者了解如何集成和使用这个库。源代码可能使用了PICO-8的Lua语法,并且可能包含了一些特定的技巧和优化,以最大限度地减少字符串的长度...
在本文中,我们将深入探讨如何使用Cocos2d框架在iOS平台上开发一款简单的推箱子游戏。Cocos2d是一款广泛使用的2D游戏开发框架,它提供了丰富的功能和易用的API,使得游戏开发者能够快速构建游戏场景、实现动画效果...
编译成功后,你就可以使用wrk对你的Web服务进行性能测试了。例如,一个简单的测试命令可能如下: ``` ./wrk -c 100 -t 10 -d 10s http://localhost:8080 ``` 这个命令将创建100个连接,使用10个线程,持续10秒,向...
标题“stay-alive-and-flex-your-time”暗示了一个与程序运行时保持活性以及时间管理相关的主题。结合标签“Lua”,我们可以推断这是一个关于使用...同时,了解和实践这些内容也能加深对Lua语言特性和编程模式的理解。
由于模型的所有实际逻辑都是用Lua编写的,因此可以编写其他语言的Thoonk包装器,这些包装器可以与thoonk.js互操作,例如Python版本thoonk.py 。正在安装npm install thoonk就其本身而言,Thoonk只是一个用于整理和...
《炉石魔塔游戏源码》是一款基于Cocos引擎,使用lua语言开发的益智休闲手游,它在经典魔塔游戏的基础上,融合了副本和爬塔两种创新玩法,为玩家带来更加丰富多元的游戏体验。本游戏的核心特点是其独特的游戏机制、...
6. **使用Lua脚本**:Lua脚本提供了原子性操作,可以在单个命令中执行多条指令,确保数据的一致性。 7. **定期配置检查与优化**:通过`config set`命令定期检查和调整Redis的配置,以适应不断变化的工作负载。 8. ...
例如,你可以使用以下代码连接Redis服务器: ```php require 'vendor/autoload.php'; // 如果使用Composer安装 // 或者 // include 'path/to/phpredis/phpredis.php'; // 如果使用phpredis扩展 $redis = new ...
了解了这些基础知识后,你可以根据自己的需求,进一步学习 Redis 的高级特性,如流(Streams)、地理空间索引(Geospatial Indexing)等,或者探索如何在实际项目中部署和使用 Redis。同时,持续关注 Redis 的更新,...
它们可能是用Lua编写的,允许玩家调整数值以适应不同的游戏策略。 2. **脚本文件**:Lua脚本用于定义角色的复杂行为,如技能施放逻辑、AI决策过程、与其他游戏元素的交互等。玩家可以通过编辑这些脚本来改变角色的...
这个应用的核心是用 Lua 语言编写的,这是一种轻量级的脚本语言,通常用于游戏开发和嵌入式系统,因为它的语法简洁且执行效率高。尽管 Lua 并非通常用于开发金融应用的语言,但其灵活性使得开发者能够快速实现功能并...
4. **lua脚本时间限制**:为lua脚本执行设定了时间限制,防止因脚本运行过久导致服务器阻塞。 5. **客户端缓存**:客户端连接缓存机制,减少了建立新连接的开销。 对于Windows环境下的Redis 6.0.8绿色解压版,安装...
Redis是一款高性能的键值对数据库,它以内存存储为主,数据持久化为辅,支持多种数据结构,如字符串、哈希、列表、集合、...这份笔记资料将帮助你全面掌握Redis,无论你是初学者还是经验丰富的开发者,都能从中受益。
...Redis是一种高性能的键值数据库,它提供了丰富的数据结构,如字符串、哈希、列表、集合、...通过了解并熟练使用这个扩展,你可以构建出高性能、低延迟的Web应用,充分利用Redis的内存数据库特性进行数据存储和处理。
而且,作者还讨论了如何使用Lua脚本在Redis内部执行自定义命令,以及如何利用Redis的发布订阅功能实现消息的发布和订阅机制。 《Redis Cookbook》的印刷历史显示,这本书是在2011年8月首次出版的,尽管时间已久,...
你可以用它来验证Redis服务器的功能是否正常,确保在修改或升级Redis时不会引入错误。 3. `redis-4.0.6.tar`:这是Redis 4.0.6版本的源代码包。每个版本的Redis都有可能包含新特性、性能优化或bug修复。4.0.6是一个...
Redis是一款高性能的键值对数据库,它以内存存储为主,数据持久化为辅,提供高速的数据读写操作。...通过这份文档手册,读者将能够全面了解Redis的基本概念、使用方法及高级特性,从而更好地在实际项目中应用Redis。