博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
通过例子学习Lua(3)----Lua数据结构(转)
阅读量:2452 次
发布时间:2019-05-10

本文共 1789 字,大约阅读时间需要 5 分钟。

通过例子学习Lua(3)----Lua数据结构(转)[@more@]

  
1.简介

  Lua语言只有一种基本数据结构, 那就是table, 所有其他数据结构如数组啦,

  类啦, 都可以由table实现.

  

  
2.table的下标

  例e05.lua

  -- Arrays

  myData = {}

  myData[0] = “foo”

  myData[1] = 42

  

  -- Hash tables

  myData[“bar”] = “baz”

  

  -- Iterate through the

  -- structure

  for key, value in myData do

  print(key .. “=“ .. value)

  end

  

  输出结果

  0=foo

  1=42

  bar=baz

  

  程序说明

  首先定义了一个table myData={}, 然后用数字作为下标赋了两个值给它. 这种

  定义方法类似于C中的数组, 但与数组不同的是, 每个数组元素不需要为相同类型,

  就像本例中一个为整型, 一个为字符串.

  

  程序第二部分, 以字符串做为下标, 又向table内增加了一个元素. 这种table非常

  像STL里面的map. table下标可以为Lua所支持的任意基本类型, 除了nil值以外.

  

  Lua对Table占用内存的处理是自动的, 如下面这段代码

    a = {}

    a["x"] = 10

    b = a   -- `b' refers to the same table as `a'

    print(b["x"]) --&gt 10

    b["x"] = 20

    print(a["x"]) --&gt 20

    a = nil  -- now only `b' still refers to the table

    b = nil  -- now there are no references left to the table

  b和a都指向相同的table, 只占用一块内存, 当执行到a = nil时, b仍然指向table,

  而当执行到b=nil时, 因为没有指向table的变量了, 所以Lua会自动释放table所占内存

  

  
3.Table的嵌套

  Table的使用还可以嵌套,如下例

  例e06.lua

  -- Table ‘constructor’

  myPolygon = {

  color=“blue”,

  thickness=2,

  npoints=4;

  {x=0,  y=0},

  {x=-10, y=0},

  {x=-5, y=4},

  {x=0,  y=4}

  }

  

  -- Print the color

  print(myPolygon[“color”])

  

  -- Print it again using dot

  -- notation

  print(myPolygon.color)

  

  -- The points are accessible

  -- in myPolygon[1] to myPolygon[4]

  

  -- Print the second point’s x

  -- coordinate

  print(myPolygon[2].x)

  

  
程序说明

  首先建立一个table, 与上一例不同的是,在table的constructor里面有{x=0,y=0},

  这是什么意思呢? 这其实就是一个小table, 定义在了大table之内, 小table的

  table名省略了.

  最后一行myPolygon[2].x,就是大table里面小table的访问方式.

 

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/8225414/viewspace-951605/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/8225414/viewspace-951605/

你可能感兴趣的文章
sql自定义报表软件_SQL Server中的报表–自定义报表的外观
查看>>
power bi数据分析_设置Power BI数据网关
查看>>
在SQL Server中截断表操作
查看>>
构建azure对话机器人_如何在5分钟内使用Azure创建聊天机器人
查看>>
sql server表分区_SQL Server中的FORCESCAN和分区表
查看>>
SQL Server中的STRING_SPLIT函数
查看>>
在SQLPackage实用工具中探索操作和任务
查看>>
如何自动执行SQL Server数据库还原
查看>>
亚马逊技能开发入门_Amazon QuickSight入门
查看>>
SQL Server Reporting Services最佳做法
查看>>
SQL FILESTREAM和SQL Server全文搜索
查看>>
SQL Server 2019中的轻量级性能分析
查看>>
学习MySQL:使用SELECT语句从MySQL服务器查询数据
查看>>
sql聚簇索引和非聚簇索引_使用SQL CREATE INDEX创建聚簇和非聚簇索引
查看>>
如何在SQL Server中索引外键列
查看>>
mysql 如何对表排序_学习MySQL:对表中的数据进行排序和过滤
查看>>
sql azure 语法_将SQL工作负载迁移到Microsoft Azure:规划迁移
查看>>
5000_500
查看>>
同步等待 异步等待_异步等待
查看>>
designmode_designMode
查看>>