- Socket 编程发展
- OpenResty 简介
- Lua 入门
- Nginx
- 子查询
- 不同阶段共享变量
- 防止 SQL 注入
- 如何发起新 HTTP 请求
- 访问有授权验证的 Redis
- select+set_keepalive 组合操作引起的数据读写错误
- redis 接口的二次封装(简化建连、拆连等细节)
- redis 接口的二次封装(发布订阅)
- pipeline 压缩请求数量
- script 压缩复杂请求
- 动态生成的 lua-resty-redis 模块方法
- LuaCjsonLibrary
- json解析的异常捕获
- 稀疏数组
- 空table编码为array还是object
- PostgresNginxModule
- 调用方式简介
- 不支持事务
- 超时
- 健康监测
- SQL注入
- LuaNginxModule
- 执行阶段概念
- 正确的记录日志
- 热装载代码
- 阻塞操作
- 缓存
- sleep
- 定时任务
- 禁止某些终端访问
- 请求返回后继续执行
- 调试
- 请求中断后的处理
- 我的 lua 代码需要调优么
- 变量的共享范围
- 动态限速
- shared.dict 非队列性质
- 正确使用长链接
- 如何引用第三方 resty 库
- 典型应用场景
- 怎样理解 cosocket
- 如何安全启动唯一实例的 timer
- 如何正确的解析域名
- LuaRestyDNSLibrary
- 使用动态 DNS 来完成 HTTP 请求
- LuaRestyLock
- 缓存失效风暴
- HTTPS 时代
- 动态加载证书和 OCSP stapling
- TLS session resumption
- 测试
- Web 服务
- 火焰图
- 如何定位问题
- module 是邪恶的
- FFI
- 什么是 JIT
文章来源于网络收集而来,版权归原创者所有,如有侵权请及时联系!
虚变量
当一个方法返回多个值时,有些返回值有时候用不到,要是声明很多变量来一一接收,显然不太合适(不是不能)。Lua 提供了一个虚变量(dummy variable)的概念, 按照惯例以一个下划线(“_”)来命名,用它来表示丢弃不需要的数值,仅仅起到占位的作用。
看一段示例代码:
-- string.find (s,p) 从string 变量s的开头向后匹配 string
-- p,若匹配不成功,返回nil,若匹配成功,返回第一次匹配成功
-- 的起止下标。
local start, finish = string.find("hello", "he") --start 值为起始下标,finish
--值为结束下标
print ( start, finish ) --输出 1 2
local start = string.find("hello", "he") -- start值为起始下标
print ( start ) -- 输出 1
local _,finish = string.find("hello", "he") --采用虚变量(即下划线),接收起
--始下标值,然后丢弃,finish接收
--结束下标值
print ( finish ) --输出 2
print ( _ ) --输出 1, `_` 只是一个普通变量,我们习惯上不会读取它的值
代码倒数第二行,定义了一个用 local 修饰的 虚变量
(即 单个下划线)。使用这个虚变量接收 string.find()
第一个返回值,忽略不用,直接使用第二个返回值。
虚变量不仅仅可以被用在返回值,还可以用在迭代等。
在for循环中的使用:
-- test.lua 文件
local t = {1, 3, 5}
print("all data:")
for i,v in ipairs(t) do
print(i,v)
end
print("")
print("part data:")
for _,v in ipairs(t) do
print(v)
end
执行结果:
# luajit test.lua
all data:
1 1
2 3
3 5
part data:
1
3
5
当有多个返回值需要忽略时,可以重复使用同一个虚变量:
多个占位:
-- test.lua 文件
function foo()
return 1, 2, 3, 4
end
local _, _, bar = foo(); -- 我们只需要第三个
print(bar)
执行结果:
# luajit test.lua
3
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论