Lua 内table遍历

在lua中有4种方式遍历一个table,当然,从本质上来说其实都一样,只是形式不同,这四种方式分别是:

1. ipairs

for index, value in ipairs(table) do

end

注:这种方式的遍历只会从key为1的地方开始,一直以key递增1的顺序来遍历,若找到一个递增不是1的key就结束遍历,无论后面是否仍然是顺序的key。

 --Sample_1:
local tab1 =
{
[] = ,
[] = ,
[] = ,
[] = ,
}
for key, value in ipairs(tab1) do
  print(value) -->1 2 3 4
end
--Sample_2:
local tab2 =
{
[] = ,
[] = ,
[] = ,
[] = ,
[] = ,
}
for key, value in ipairs(tab2) do
print(value) -->1 2 3
end
--Sample_3:
local tab3 =
{
[] = ,
[] = ,
[] = ,
}
for key, value in ipairs(tab3) do
print(value) -->没有打印
end

2. pairs

for key, value in pairs(table) do

end

这种方式的遍历是根据table中key的hash值排列的顺序来遍历,并非是table中key的排列顺序,并且不关心key是否从1开始和key是否以1递增。

--Sample_1:
local tab1 =
{
[] = ,
[] = ,
[] = ,
[] = ,
} for key, value in pairs(tab1) do
print(value) -->1 2 4 3
end
--Sample_2:
local tab2 =
{
[] = ,
[] = ,
[] = ,
[] = ,
[] = ,
}
for key, value in pairs(tab2) do
print(value) -->6 2 3 1 5
end
--Sample_3:
local tab3 =
{
[""] = ,
[""] = ,
[""] = ,
[""] = ,
[""] = ,
}
for key, value in pairs(tab3) do
print(value) -->1 3 2 5 6
end

3. #table

for i=1, #(table) do

end

注:这种方式的遍历关键的地方在于获取table的大小,#(table)只会从key为1的地方开始,一直以key递增1的顺序来遍历,若找到一个递增不是1的key就结束遍历并且返回table的大小,无论后面是否仍然是顺序的key。

--Sample_1:
local tab1 =
{
[] = ,
[] = ,
[] = ,
[] = ,
} print("#table:"..#(tab1)) -->4
for i = , #(tab1) do
print(tab1[i]) -->1 2 3 4
end --Sample_2:
local tab2 =
{
[] = ,
[] = ,
[] = ,
[] = ,
[] = ,
} print("#table:"..#(tab2)) -->3
for i = , #(tab2) do
print(tab2[i])
end
--Sample_3:
local tab3 =
{
[] = ,
[] = ,
[] = ,
} print("#table:"..#(tab3)) -->0
for i = , #(tab3) do
print(tab3[i]) -->没有打印
end

4. table.maxn(table)

  这种方式的遍历和第三种方式差不多,关键的地方是在table.maxn(table),table.maxn(table)的意思是获取table中最大值的key。 

local tab2 =
{
[] = ,
[] = ,
[] = ,
["a"] = ,
[] = ,
[] = ,
} print("table.maxn:"..table.maxn(tab2)) -->6
for i = , table.maxn(tab2) do
print(tab2[i]) -->1 2 3 nil 5 6
end
--Sample_2:
local tab3 =
{
[] = ,
[] = ,
[] = ,
} print("table.maxn:"..table.maxn(tab3)) -->4
for i = , table.maxn(tab2) do
print(tab3[i]) -->nil 2 3 4 nil nil
end

Lua table移除某一项,或多项内容

  有两种方式来移除table中的数据

1. 按下标来移除

  table.remove(table_name, [pos,])
  直接移除某个下标的数据,例如:

local t = {, , , }
table.remove(t, )
for k, v in pairs(t) do
print(k, v)
end
输出

2.将某项值置空

  table[k] = nil  直接将某项值置空

  

local a = {
[''] = ,
[''] = ,
[''] = ,
[''] =
} a[''] = nil for k, v in pairs(a) do
print(k, v)
end 输出:

lua中table的遍历,以及删除的更多相关文章

  1. lua中 table 元表中元方法的重构实现

    转载请标明出处http://www.cnblogs.com/zblade/ lua作为游戏的热更新首选的脚本,其优势不再过多的赘述.今天,我主要写一下如何重写lua中的元方法,通过自己的重写来实现对l ...

  2. lua中 table 重构index/pairs元方法优化table内存占用

    转载请标明出处http://www.cnblogs.com/zblade/ lua作为游戏的热更新首选的脚本,其优势不再过多的赘述.今天,我主要写一下如何重写lua中的元方法,通过自己的重写来实现对l ...

  3. lua中 table.getn(t) 、#t、 table.maxn(t) 这三个什么区别?

    lua中 table.getn(t) .#t. table.maxn(t) 这三个什么区别? RTlocal t = {1,888,x= 999,b=2,5,nil,6,7,[10]=1,8,{z = ...

  4. lua中table如何安全移除元素

    在Lua中,table如何安全的移除元素这点挺重要,因为如果不小心,会没有正确的移除,造成内存泄漏. 引子 比如有些朋友常常这么做,大家看有啥问题 将test表中的偶数移除掉local test = ...

  5. Lua中table的实现-《Lua设计与实现》

    本文来自<Lua设计与实现>的阅读笔记,推荐Lua学习者可以购买一本,深入浅出讲解lua的设计和实现原理,很赞,哈哈   Lua中对于表的设计,是基于数组和散列表,和其他语言不同,对于数组 ...

  6. Java中ArrayList循环遍历并删除元素的陷阱

    ava中的ArrayList循环遍历并且删除元素时经常不小心掉坑里,昨天又碰到了,感觉有必要单独写篇文章记一下. 先写个测试代码: import java.util.ArrayList; public ...

  7. C++对Lua中table进行读取、修改和创建

    C++代码: // LuaAndC.cpp : 定义控制台应用程序的入口点. // #include "stdafx.h" #include <iostream> #i ...

  8. Lua中Table的学习

    --table 是 Lua 的一种数据结构,用来帮助我们创建不同的数据类型,如:数组.字典等 --Lua也是通过table来解决模块(module).包(package)和对象(Object)的. 例 ...

  9. lua中table的常用方法

    转载:https://blog.csdn.net/Fenglele_Fans/article/details/83627021 1:table.sort() language = {"lua ...

随机推荐

  1. 自己总结的C#编码规范--3.特定场景下的命名最佳实践

    特定场景下的命名最佳实践 命名空间 要使用PascalCasing,并用点号来分隔名字空间中的各个部分. 如Microsof.Office.PowerPoint 要用公司名作为命名空间的前缀,这样就可 ...

  2. 牛客国庆集训派对Day1.B.Attack on Titan(思路 最短路Dijkstra)

    题目链接 \(Description\) 给定\(n,m,C\)及大小为\((n+1)(m+1)\)的矩阵\(c[i][j]\).平面上有\((n+1)(m+1)\)个点,从\((0,0)\)编号到\ ...

  3. Unable to find utility "instruments", not a developer tool or in PATH

    在调试ios上的项目的时候出现报错 unable to find utility "instruments", not a developer tool or in PATH 报错 ...

  4. python2和python3比较好的共存方法

    文章根据网络资料编写,只为个人学习使用.青山... ---------------------------------------------------- 由于工作学习的需求,大家都想同时安装pyt ...

  5. BZOJ4738 : 汽水

    二分答案$mid$,若存在一条路径满足$|ave-k|<mid$,则答案至多为$mid-1$. 若$ave\leq k$,则$\sum(w-k)\leq 0$,且$\sum(k-w-mid)&l ...

  6. Sniffer初识

    Sniffer,中文可以翻译为嗅探器,是一种基于被动侦听原理的网络分析方式.使用这种技术方式,可以监视网络的状态.数据流动情况以及网络上传输的信息.当信息以明文的形式在网络上传输时,便可以使用网络监听 ...

  7. UE4入门(三)

  8. openstack之Neutron网络虚拟化

    第一:为什么需要网络虚拟化? 一.数据中心的现有网络不能满足云计算的物理需求: 互联网行业数据中心的基本特征就是服务器的规模偏大.进入云计算时代后,其业务特征变得更加复杂,包括:虚拟化支持.多业务承载 ...

  9. [原创]RedisDesktopManager工具使用介绍

    [原创]RedisDesktopManager工具使用介绍 1 RedisDesktopManager简介 一款能够跨平台使用的开源性redis可视化工具.redis desktop manager主 ...

  10. 11、TopN实战

    1.Java版本: 1.1.取前3 package sparkcore.java; import java.util.List; import org.apache.spark.SparkConf; ...