Lua无法排序的问题(Key需要是连续的)

Posted zhaoqingqing

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Lua无法排序的问题(Key需要是连续的)相关的知识,希望对你有一定的参考价值。

排序的Key需要是连续的

local x = {[1]={x=6},
           [2]={x=5},
           [3]={x=7},
           [5]={x=2},
           [6]={x=8},
           [7]={x=5}}
---从小到大排序
table.sort(x,function(a,b)
    return a.x < b.x
end)

for i=1,10 do
    if x[i] ~= nil then 
        print(x[i].x)
    end
end

打印出:5,6,7, 2,8,5
可以看到后面的数据并没有进行排序,因为key不是连续的,中间存在断层,Lua只会对连续的部分进行排序。

非连续Key不能排序

local x = { [101] = { x = 6 },
                 [2] = { x = 5 },
                 [10] = { x = 7 } }
print("排序前:", table.tostring(x))
---从小到大排序
table.sort(x, function(a, b)
    return a.x < b.x
end)
print("排序后:", table.tostring(x))

打印出:排序前和排序后数据是一样的,同样验证 Lua只会对连续的部分进行排序

排序前:    {
  101 = {
    x = 6,
  },
  2 = {
    x = 5,
  },
  10 = {
    x = 7,
  },
}
排序后:    {
  101 = {
    x = 6,
  },
  2 = {
    x = 5,
  },
  10 = {
    x = 7,
  },
}

以上是关于Lua无法排序的问题(Key需要是连续的)的主要内容,如果未能解决你的问题,请参考以下文章

在 Lua 中按值关联排序表

Lua中的数组排序

算法之交换排序

redis实现连续自增key

lua 4 使用table实现其他数据结构,并介绍遍历方法

Lua遍历table