工作中,栽了一个“坑”,特此备录。

【1】遍历table1,每次结果可能都不同

-- 获取value
local table_1 = {id="", name="wang", sage="", addr="xian"}
for k, v in pairs(table_1) do
print(k, v)
end

每次结果可能都不同

【2】遍历table2,每次结果相同

 local table_2 = {"", "wang", "", "xian"}

 print('len2 : ' .. (#table_2))

 local value_idx = {}
for i = , #table_2 do
print(i .. ' '.. table_2[i])
table.insert(value_idx, table_2[i])
end
print(table.concat(value_idx, ",")) for k,v in ipairs(table_2) do
print(k, v)
end --[[
len2 : 4
1 101
2 wang
3 18
4 xian
101,wang,18,xian
1 101
2 wang
3 18
4 xian
--]]

每次结果相同

【3】table遍历的方法

经学习,总结一下table遍历的四种方法:

(3.1)利用迭代器pairs的方式

形式如下:

for key, value in pairs(tbtest) do
-- TODO
end

示例如上第一节的实例,不再赘述。

特点:一定会遍历所有的元素,但并非按tbtest中key的排列顺序,而是根据tbtest中key的hash值排列的顺序来遍历的。

(3.2)利用迭代器ipairs的方式

形式如下:

for key, value in ipairs(tbtest) do
-- TODO
end

示例如上第二节的实例,另外,再如下:

 tbtest = {[] = , [] = , [] = , [] = } 

 for key, value in ipairs(tbtest) do
print('key : ' .. key .. ' value : ' .. value)
end --[[
key : 1 value : 100
key : 2 value : 200
key : 3 value : 300
--]]

特点:必须要求tbtest中的key为顺序的,且必须是从1开始,ipairs只会从1开始按连续的key顺序遍历到key不连续为止。

(3.3)下标索引方式

形式如下:

for i = , #(tbtest) do
-- TODO
end

示例如上第二节的实例,不再赘述。

特点:只能遍历当tbtest中存在key为1的场景,而且是严格按照key从1开始依次递增1的顺序来遍历,找不到下一个递增是1的key时候就结束遍历,无论后面是否是顺序的key

(3.4)自定义迭代器

形式如下:

function pairsByKeys(t)
local a = {}
for n in pairs(t) do
a[#a+] = n
end
table.sort(a)
local i =
return function()
i = i +
return a[i], t[a[i]]
end
end for key, value in pairsByKeys(tbtest) do
if destKey <= key then
-- TODO
end
end

应用场景:

网上有个实际的应用场景,感觉挺应景的。比如,学校按照班级排名顺序给学生发奖金,规则如下:

1.1 排名前4(1,2,3,4)的学生奖励500元

1.2 排名前8(5,6,7,8)的学生奖励300元

1.3 排名前12(9,10,11,12)的学生奖励200元

1.4 排名前16(13,14,15,16)的学生奖励100元

现在,准备给小王发奖金,小王排名第7名,理论应该发奖金是300元。

但是,对比方式(1)和方式(4)的遍历结果如下:

 tbtest = {[] = , [] = , [] = , [] = } 

 function pairsByKeys(t)
local a = {}
for n in pairs(t) do
print('n : ' .. n)
a[#a+] = n
end
table.sort(a)
local i =
return function()
i = i +
return a[i], t[a[i]]
end
end print('-------------方式(3.1)-------------')
for k, v in pairs(tbtest) do
if <= k then
print('pairs : ' .. k .. ' value : ' .. v)
break
end
end print('-------------方式(3.4)-------------')
for key, value in pairsByKeys(tbtest) do
print('key : ' .. key .. ' value : ' .. value)
if <= key then
print('pairsByKeys : ' .. key .. ' value : ' .. value)
return
end
end --[[
-------------方式(3.1)-------------
pairs : 12 value : 200
-------------方式(3.4)-------------
n : 4
n : 12
n : 8
n : 16
key : 4 value : 500
key : 8 value : 300
pairsByKeys : 8 value : 300
--]]

原因分析:因为方式(1)是按照key值的hash值进行遍历的,而不是按照key值的大小顺序进行遍历。

而方式(4)对方式(1)做了改进,先对所有的key值进行了排序,然后再依次遍历,满足预期的效果。

综上所述:方式(4)是对方式(1)的不足进行了弥补,具体应用过程中,根据实际情况,择优选择遍历方法。

Good Good Study, Day Day Up.

顺序 选择 循环 总结

Lua table遍历的更多相关文章

  1. Lua Table pairs输出顺序问题 (版本差异 解决数字索引间断并兼容字符串索引)

    问题标签: Lua Table 迭代器;Lua Table 输出顺序; Lua Table 顺序输出;Lua Table 数字索引 字符串索引;Lua Table pairs; 问题背景: 使用pai ...

  2. lua中遍历table的几种方式比较

    当我在工作中使用lua进行开发时,发现在lua中有4种方式遍历一个table,当然,从本质上来说其实都一样,只是形式不同,这四种方式分别是: for key, value in pairs(tbtes ...

  3. lua table integer index 特性

    table.maxn (table) Returns the largest positive numerical index of the given table, or zero if the t ...

  4. lua table remove元素的问题

    当我在工作中使用lua进行开发时,发现在lua中有4种方式遍历一个table,当然,从本质上来说其实都一样,只是形式不同,这四种方式分别是: for key, value in pairs(tbtes ...

  5. lua table表判断是否为空

    官方手册里早已经给了答案,那就是靠lua内置的next函数 即如此用: a = {} if next(a) == nil then next其实就是pairs遍历table时用来取下一个内容的函数. ...

  6. 关于 lua table表存储函数且运用

    --table 是lua的一种数据结构用来帮助我们创建不同的数据类型.如:数组和字典--lua table 使用关联型数组,你可以用任意类型的值来做数组的索引,但这个值不能是nil--lua tabl ...

  7. 【Lua】Lua + openresty遍历文件目录

    OpenResty (也称为 ngx_openresty)是一个全功能的 Web 应用服务器,它打包了标准的 Nginx 核心,很多的常用的第三方模块,以及它们的大多数依赖项. 今天用OpenRest ...

  8. Lua 学习之基础篇四<Lua table(表)>

    table 是 Lua 的一种数据结构用来帮助我们创建不同的数据类型,如:数组.字典等. Lua table 使用关联型数组,你可以用任意类型的值来作数组的索引,但这个值不能是 nil. Lua ta ...

  9. 树形打印lua table表

    为方便调试lua程序,往往想以树的形式打印出一个table,以观其表内数据.以下罗列了三种种关于树形打印lua table的方法;法一 local print = print local tconca ...

随机推荐

  1. CSS入门介绍(一)

    css 层叠样式表(英文名:Cascading Style Sheets),主要用于美化网页 1.css的表现形式 1.1 行内样式(内嵌样式) 写在标签内的样式,写在标签的开始部分的内部,style ...

  2. C_使用clock()函数获取程序执行时间

    clock():捕捉从程序开始运行到clock()被调用时所耗费的时间.这个时间单位是clock tick ,即“时钟打点”. 常数CLK_TCK:机器时钟每秒所走的时钟打点数. #include & ...

  3. Java数据库连接与查询

    9个步骤: 1.加载数据库驱动: 2.连接数据库: 3.创建语句statement: 5.创建sql语法字符串: 6.执行: 7.如果步骤6是执行新增.修改.删除操作那么返回的是影响的行数,如果是执行 ...

  4. [bzoj1051]Popular Cows

    刚刚被ysy在联考里虐了,差点爆tan(pi/4),只好来bzoj寻求安慰再被虐一次233 (tarjan是什么智障东西不想打我好弱啊,tarjan都不会打) Description 每一头牛的愿望就 ...

  5. 使用javascript和css模拟帧动画的几种方法浅析

    我们平时在开发前端页面的时候,经常会播放一段帧序列.这段帧序列就像gif图片那样,反复循环播放.那大家可能会说,直接用gif图片就好了,干嘛还去模拟呢?那是因为要做得更加灵活,我们要做到以下几点: 1 ...

  6. help文档制作 chm

    程序中的help文档制作 所用工具:HTML Help Workshop 文件包括:各个html文档,帮助页面的具体内容 hhc文档:help的目录文件 hhk文档:help的索引文件 MAP文件夹中 ...

  7. Centos7 Nagios 搭建

    Nagios 是一款自动化运维工具,可以协助运维人员监控服务器的运行状况,并且拥有报警功能.本文章将介绍其安装方法和详细的配置方法. 总结 可以做资源,网络,应用服务的监控 配置上需要配置被监控的,服 ...

  8. 黑盒测试实践——day06

    一.任务进展情况 通过小组成员的共同努力,终于完成了此次“黑盒测试实践”任务.目前的主要任务将之前的文件汇总,整理出来.                             二.存在的问题 由于此 ...

  9. Kotlin从入门到放弃

    1.eclipse kotlin安装: http://blog.csdn.net/u014134488/article/details/50684922 2.Android Studio kotlin ...

  10. 使用MDI 和 XtraTabbedMdiManager 后 选项卡切换后Ribbon 合并后不选中MDI子窗...

    使用MDI 和 XtraTabbedMdiManager 后 选项卡切换后Ribbon 合并后不选中MDI子我这里是 继承 XtraTabbedMdiManager  所以,是重载的  OnSelec ...