Lua数据结构的学习笔记

一. table
table是lua唯一的数据结构。table 是 lua 中最重要的数据类型。 table 类似于 python 中的字典。table 只能通过构造式来创建。其他语言提供的其他数据结构如array、list等等,lua都是通过table来实现的。table非常实用,可以用在不同的情景下。最常用的方式就是把table当成其他语言的数组。
实例1:

 代码如下 复制代码
mytable = {}
for index = 1, 100 do
    mytable[index] = math.random(1,1000)
end

说明:
1). 数组不必事先定义大小,可动态增长。
2). 创建包含100个元素的table,每个元素随机赋1-1000之间的值。
3). 可以通过mytable[x]访问任意元素,x表示索引。
4). 索引从1开始。

实例2:

 代码如下 复制代码
tab = { a = 10, b = 20, c = 30, d = 'www.ttlsa.com' }
print(tab["a"]) :

说明:
1). table 中的每项要求是 key = value 的形式。
2). key 只能是字符串, 这里的 a, b, c, d 都是字符串,但是不能加上引号。
3). 通过 key 来访问 table 的值,这时候, a 必须加上引号。

实例3:

 代码如下 复制代码
tab = { 10, s = 'www.ttlsa.com', 11, 12, 13 }
print(tab[1]) = 10
print(tab[2]) = 11
print(tab[3]) = 12
print(tab[4]) = 13

说明:
1). 数标从1开始。
2). 省略key,会自动以1开始编号,并跳过设置过的key。

二. table函数
lua提供了许多实用的内建函数来操作table。
2.1 table.getn(table)
返回table中的元素个数。

 代码如下 复制代码
print(table.getn(tab)) -> 4

2.2 table.insert(table,position,value)
在table中插入一个新的值,位置参数可选的,如果没有指定,会添加table的末尾,否则插入到指定的位置。

 代码如下 复制代码
table.insert(tab, 2, “hello ttlsa.com”)

插入”hello ttlsa.com”到table的第2个元素的位置,并重新索引。

2.3 table.remove(table,position)
从指定table中删除并返回一个元素,如果没有指定position值,则默认删除最后一个元素。

 代码如下 复制代码
print(table.remove(tab,2)) -> hello ttlsa.com

三. table引用
table不仅可以使用数字索引,也可以用其他值作为索引值。

 代码如下 复制代码
tab = ()
tab.website = "www.ttlsa.com"
tab.QQ = "39514058"
tab.a = math.random(1,10)
tab[1] = 11
tab[2] = 22

四. 多维table
在lua中创建多维table非常容易的。可以把多维table看做是table的table。可以通过多个关键字来访问。

 代码如下 复制代码
multitab = {}
multitab.name = {}
multitab.author = {}
multitab.name[1] = "QQ qun: 39514058"
multitab.name[2] = "website: http://www.ttlsa.com"
multitab.author[1] = "默北"
multitab.author[2] = "凉白开"
multitab.author[3] = "tonyty163"

五. 遍历table
pairs()函数可以遍历table中的每个元素。

 代码如下 复制代码
tab = { 10, s = 'www.ttlsa.com', 11, 12, 13 }
for k, v in pairs(tab) do
    print(k, ":", v)
end
输出:
1 : 10
2 : 11
3 : 12
4 : 13
s : www.ttlsa.com

pairs()函数遍历整个table,即使不知道table长度,并返回索引值和相对应的元素值

矩阵和多维数组:
 
每行一个table,

 代码如下 复制代码
mt = {} -- create the matrix
for i=1,N do
  mt[i] = {} -- create a new row
  for j=1,M do
    mt[i][j] = 0
  end
end

 
所有数据在一个table中

 代码如下 复制代码
mt = {} -- create the matrix
for i=1,N do
  for j=1,M do
    mt[i*M + j] = 0
  end
end

 
 
链表:
list = nil
在list前插入一个元素:
list = {next = list, value = v}
 
遍历:

 代码如下 复制代码
local l = list
  while l do
    print(l.value)
    l = l.next
  end
 队列:
List = {}
function List.new ()
  return {first = 0, last = -1}
end

左侧添加,first减1,左侧删除first加1,
右侧添加,last加1,右侧删除last减1,
first大于last则表示队列空
 
集合:
这是一个关键字的集合:

 代码如下 复制代码
reserved = {
["while"] = true, ["end"] = true,
["function"] = true, ["local"] = true,
}

说明:集合的元素是table的键,而不是值。
原始集合是:{"while", "end", "function", "local", }

原文来自:http://www.ttlsa.com/lua/lua-data-structure-ttlsa/

时间: 2024-09-27 05:05:35

Lua数据结构的学习笔记的相关文章

Lua面向对象编程学习笔记_Lua

其实 Lua 中的 table 是一种对象,因为它跟对象一样,有其自己的操作方法: 复制代码 代码如下: Role = { hp = 100 } function Role.addHp(hp)     Role.hp = Role.hp + hp end   Role.addHp(50) print(Role.hp) 上面代码创建了一个名为 Role 对象,并有一个 addHp 的方法,执行 "Role.addHp" 便可调用 addHp 方法. 不过上面对象 Role 是以全局变量的

Lua table类型学习笔记_Lua

关系表类型,这是一个很强大的类型.我们可以把这个类型看作是一个数组.只是 C语言的数组,只能用正整数来作索引: 在Lua中,你可以用任意类型的值来作数组的索引,但这个值不能是 nil.同样,在C语言中,数组的内容只允许一种类型:在 Lua中,你也可以用任意类型的值来作数组的内容,nil也可以. 基本介绍 注意三点: 第一,所有元素之间,总是用逗号 "," 隔开: 第二,所有索引值都需要用 "["和"]" 括起来:如果是字符串,还可以去掉引号和中括

lua类库 middleclass学习笔记

middleclass使在lua中面象对象变的简单 抄了一遍他的示例代码运行着试了试,基本懂了 local class = require 'middleclass' --类的继承 Person = class('Person') --定义一个Person类 function Person:initialize(name) --构造函数 self.name = name end function Person:speak() --方法 print("Hi,i am " ..self.n

Lua学习笔记之类型与值_Lua

基础介绍 Lua是一种动态类型的语言.在语言中没有类型定义的语法,每个值都带有其自身的类型信息.在Lua中有8种基本类型,分别是: nil(空)类型 boolean(布尔)类型 number(数字)类型 string(字符串)类型 userdata(自定义类型) function(函数)类型 thread(线程)类型 table(表)类型 以上是Lua中的8中基本类型,我们可以使用type函数,判断一个值得类型,type函数返回一个对应类型的字符串描述.例如: local iValue = 10

php5学习笔记(转)

php5|笔记 作者: whhwq在phpv.net看到的感觉不错/*+-------------------------------------------------------------------------------+| = 本文为Haohappy读<<Core PHP Programming>> | = 中Classes and Objects一章的笔记 | = 翻译为主+个人心得 | = 为避免可能发生的不必要的麻烦请勿转载,谢谢 | = 欢迎批评指正,希望和所有

数据库学习笔记(一)

笔记|数据|数据库 这是我学习数据库时候的笔记,都是非常简单,非常基础的有关数据库的知识,最近整理一下,希望大家不要蛋蛋我啊,呵呵 数据库学习笔记(一)                         --绪论及基本概念 一,             数据:描述事物的符号记录称为数据. 二,             数据库:指长期存储在计算机内的.有组织.可共享的数据集合. 三,             数据库管理系统:数据管理的软件,主要以下功能:                   1, 

Duwamish7学习笔记1

笔记 Duwamish7学习笔记(-)   Duwamish解决方案总共有6个项目,结构上分为5层:业务外观层(BusinessFacade).业务规则层(BusinessRules).业务实体层(Common).数据访问层(DataAccess).业务展示层(Web).另外一项目为SystemFrameWork,顾名思意,主要是用来进行整个系统构架的一些配置.跟踪.日志等.  Common项目  1.让我们来看一看Duwamish7的数据结构,图1        2.对数据库中Book,Cat

作为一个新手的Oracle(DBA)学习笔记

Oracle数据库笔记 Jack Chaing 作者QQ595696297 交流群 127591054 祝大家学习进步. 如果大家想看Word版本的可以去下载:Word排版比较清晰一些. http://download.csdn.net/detail/jack__chiang/9810532 此笔记是作者本人去年开始从一个DBA新人的学习笔记,积累至今,希望拿出来给那些对DBA有兴趣的童孩学习,大家一起努力嘛. 此笔记记录了作者工作学习中从零基础的学习的记录,和从中遇见的问题与问题的解决!很高兴

Akka学习笔记(五):Akka与Java的内存模型

Akka学习笔记(五):Akka与Java的内存模型 Akka简化了编写并发软件的过程,本文主要讨论Akka如何在并发应用中访问共享内存. Java内存模型 Java5之前的JMM是相当混乱的.多线程访问共享内存很有可能会得奇怪的结果,如: 可见性问题,无法及时看到其他线程写入的值 指令乱序,观测到其他线程不可能的行为 从Java 5的JSR 133的实现,很多问题就解决了.JMM是基于一组"happens-before"关联规则,限制了访问内存的行为必须在另一个内存访问行为之前发生.