Lua table笔记

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



记录我在使用lua的过程中的一些笔记

默认key为数字递增#

local tb={"A",[3]="C","B"}
这个tb通过下标1,2,3打印出来是:ABC

ipairs和pair#

ipair的键是有顺序的从1到n,遇到nil结束遍历,pair是无顺序的,会完整遍历table

某它解释:

ipair是从key=1,开始累加,遇到val是nil就结束循环。

pair输出的结果和table定义的顺序是一致的(非数组不保证与声明的顺序一致)。

table.insert#

语法:table.insert(要插入的table,要插入的数据)

next#

next(table [, index])
解释:使程序可以遍历表table的所有字段。他的第一个参数是一个表,第二个参数是一个表中有效的索引。函数会返回表中相对于指定索引的下一个索引和索引位置的值,当我们将第二个参数设置为nil调用函数时,函数会返回这个表的初始索引和该索引位置的值,当我们使用表的最后一个索引或者在空表中使用nil做索引时,函数就会返回nil。当我们省略第二个参数时,它会被默认解释成nil。特别的,你可以使用next(t)的形式来检测表是否为空。

示例:

Copy
if next(self.data) then local item = self.data[1] else warn("列表数据为空") end

sort排序#

如果希望第一个参数排在第二个参数前面,应该返回true。如果没有提供,sort使用默认的<操作。

示例:可领取的排在前面,其它按时间进行排序

Copy
---NOTE 让vo1在vo2的前面返回true table.sort(self.data, function(vo1, vo2) if not canRecv(vo1) and not canRecv(vo2) then ---按时间排序 return vo1.initTime < vo2.initTime end if canRecv(vo1) and not canRecv(vo2) then return true end ---让vo2在vo1的前面,返回false if canRecv(vo2) and not canRecv(vo1) then return false end end)

删除table元素#

在使用for(遍历)table时,不要对这个table的元素进行删除操作

正确的做法是把需要删除的数据缓存到某个table中,然后再进行删除

示例:

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