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

本文为作者原创,转载请注明出处:https://www.cnblogs.com/zhaoqingqing/p/9572149.html



排序的Key需要是连续的#

Copy
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不能排序#

Copy
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只会对连续的部分进行排序

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

解决办法#

Copy
local tb = { [101] = { x = 6 }, [2] = { x = 5 }, [10] = { x = 7 } } --保存全部的key local keys = {} for k, v in pairs(tb) do table.insert(keys, k) end --对key进行排序 table.sort(keys, function(a, b) return a < b end) for i, key in ipairs(keys) do local data = tb[key] end
作者:赵青青   一名在【网易游戏】做游戏开发的程序员,擅长Unity3D,游戏开发,.NET等领域。
本文版权归作者和博客园共有,欢迎转载,转载之后请务必在文章明显位置标出原文链接和作者,谢谢。
如果本文对您有帮助,请点击【推荐】您的赞赏将鼓励我继续创作!想跟我一起进步么?那就【关注】我吧。
posted @   赵青青  阅读(1527)  评论(0编辑  收藏  举报
编辑推荐:
· .NET Core 托管堆内存泄露/CPU异常的常见思路
· PostgreSQL 和 SQL Server 在统计信息维护中的关键差异
· C++代码改造为UTF-8编码问题的总结
· DeepSeek 解答了困扰我五年的技术问题
· 为什么说在企业级应用开发中,后端往往是效率杀手?
阅读排行:
· 10亿数据,如何做迁移?
· 推荐几款开源且免费的 .NET MAUI 组件库
· 清华大学推出第四讲使用 DeepSeek + DeepResearch 让科研像聊天一样简单!
· 易语言 —— 开山篇
· Trae初体验
历史上的今天:
2014-09-01 C#集合类
CONTENTS
点击右上角即可分享
微信分享提示