Lua中ipairs和pairs的区别详解

迭代器for遍历table时,ipairs和pairs的区别:

区别一:ipairs遇到nil会停止,pairs会输出nil值然后继续下去

区别二:

local a = {"Hello", "World", a = 1, b = 2, x = 10, y = 20, "Good", nil, "Bye"}
-- for i,v in ipairs(a) do
--     print(v)
-- end
for k,v in pairs(a) do
    print(k,v)
end

可见:ipairs并不会输出table中存储的键值对,会跳过键值对,然后顺序输出table中的值,遇到nil则会停止。

而pairs会输出table中的键和键值对,先顺序输出值,再乱序(键的哈希值)输出键值对。

这是因为,table在存储值的时候是按照顺序的,但是在存储键值对的时候是按照键的哈希值存储的,并不会按照键的字母顺序或是数字顺序存储。

=》对于a来说,如果执行print(a[3]),输出的结果也会是Good。也就是说table并不会给键值对一个索引值。

也就是说,ipairs知识按照索引值顺序,打印出了table中有索引的数据,没有索引值的不管。

而pairs是先按照索引值打印,打印完成后再按照键值对的键的哈希值打印它的值。


所以,怎么顺序输出一个table里面的键值对?

local tab = {
    key1 = 1,
    key2 = 2,
    key3 = 3,
    key4 = 4,
    key5 = 5,
    key6 = 6,
    key7 = 7,
}

function getLen(tab)
    local len = 0
    for _,v in pairs(tab) do
        len = len + 1
    end
    return len
end

local key
for i=1,getLen(tab) do
    key = "key"..i
    print(key, tab[key])
end

还有一种更好的方法:

insert进一个新的数组,然后进行排序:

tab1 = {}
tab1[8]='8'
tab1[6]='6'
tab1[10]='10'
tab1[15]='15'
tab2 = {}
for k,v in pairs(tab1) do
    local temp = {k,v}
    table.insert(tab2, temp)
    -- table.insert(tab2, v)
end
table.sort(tab2, function(a,b)
    -- return tonumber(a)<tonumber(b)
    return a[1]<b[1]
end)
for k,v in pairs(tab2) do
    print(k,v[1],v[2])
end

  • 1
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Kerven_HKW

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值