zoukankan      html  css  js  c++  java
  • lua table

    -- 简单的 table
    mytable = {}
    print("mytable 的类型是 ",type(mytable))
    
    mytable[1]= "Lua"
    mytable["wow"] = "修改前"
    print("mytable 索引为 1 的元素是 ", mytable[1])
    print("mytable 索引为 wow 的元素是 ", mytable["wow"])
    
    -- alternatetable和mytable的是指同一个 table
    alternatetable = mytable
    
    print("alternatetable 索引为 1 的元素是 ", alternatetable[1])
    print("mytable 索引为 wow 的元素是 ", alternatetable["wow"])
    
    alternatetable["wow"] = "修改后"
    
    print("mytable 索引为 wow 的元素是 ", mytable["wow"])
    
    -- 释放变量
    alternatetable = nil
    print("alternatetable 是 ", alternatetable)
    
    -- mytable 仍然可以访问
    print("mytable 索引为 wow 的元素是 ", mytable["wow"])
    
    mytable = nil
    print("mytable 是 ", mytable)

    mytable 的类型是 table


    mytable 索引为 1 的元素是 Lua mytable 索引为 wow 的元素是 修改前




    alternatetable 索引为 1 的元素是 Lua mytable 索引为 wow 的元素是 修改前


    mytable 索引为 wow 的元素是 修改后

    alternatetable 是 nil


    mytable 索引为 wow 的元素是 修改后

    mytable 是 nil

     

    table的变量相当于一个指针,赋值后指向同一块内存,赋值为nil时这个指针为NULL,而table占用的内存在没有指针指向它后由GC释放

    Table 操作

    以下列出了 Table 操作常用的方法:

    序号方法 & 用途
    1 table.concat (table [, sep [, start [, end]]]):

    concat是concatenate(连锁, 连接)的缩写. table.concat()函数列出参数中指定table的数组部分从start位置到end位置的所有元素, 元素间以指定的分隔符(sep)隔开。

    2 table.insert (table, [pos,] value):

    在table的数组部分指定位置(pos)插入值为value的一个元素. pos参数可选, 默认为数组部分末尾.

    3 table.maxn (table)

    指定table中所有正数key值中最大的key值. 如果不存在key值为正数的元素, 则返回0。(Lua5.2之后该方法已经不存在了,本文使用了自定义函数实现)

    4 table.remove (table [, pos])

    返回table数组部分位于pos位置的元素. 其后的元素会被前移. pos参数可选, 默认为table长度, 即从最后一个元素删起。

    5 table.sort (table [, comp])

    对给定的table进行升序排序。

    接下来我们来看下这几个方法的实例。

    Table 连接

    我们可以使用 concat() 方法来连接两个 table:

    fruits = {"banana","orange","apple"}
    -- 返回 table 连接后的字符串
    print("连接后的字符串 ",table.concat(fruits))
    
    -- 指定连接字符
    print("连接后的字符串 ",table.concat(fruits,", "))
    
    -- 指定索引来连接 table
    print("连接后的字符串 ",table.concat(fruits,", ", 2,3))

    执行以上代码输出结果为:

    连接后的字符串     bananaorangeapple
    连接后的字符串     banana, orange, apple
    连接后的字符串     orange, apple

    插入和移除

    以下实例演示了 table 的插入和移除操作:

    fruits = {"banana","orange","apple"}
    
    -- 在末尾插入
    table.insert(fruits,"mango")
    print("索引为 4 的元素为 ",fruits[4])
    
    -- 在索引为 2 的键处插入
    table.insert(fruits,2,"grapes")
    print("索引为 2 的元素为 ",fruits[2])
    
    print("最后一个元素为 ",fruits[5])
    table.remove(fruits)
    print("移除后最后一个元素为 ",fruits[5])

    执行以上代码输出结果为:

    索引为 4 的元素为     mango
    索引为 2 的元素为     grapes
    最后一个元素为     mango
    移除后最后一个元素为     nil

    Table 排序

    以下实例演示了 sort() 方法的使用,用于对 Table 进行排序:

    fruits = {"banana","orange","apple","grapes"}
    print("排序前")
    for k,v in ipairs(fruits) do
        print(k,v)
    end
    
    table.sort(fruits)
    print("排序后")
    for k,v in ipairs(fruits) do
        print(k,v)
    end

    执行以上代码输出结果为:

    排序前
    1    banana
    2    orange
    3    apple
    4    grapes
    排序后
    1    apple
    2    banana
    3    grapes
    4    orange

    Table 最大值

    table.maxn 在 Lua5.2 之后该方法已经不存在了,我们定义了 table_maxn 方法来实现。

    以下实例演示了如何获取 table 中的最大值:

    function table_maxn(t)
      local mn=nil;
      for k, v in pairs(t) do
        if(mn==nil) then
          mn=v
        end
        if mn < v then
          mn = v
        end
      end
      return mn
    end
    tbl = {[1] = 2, [2] = 6, [3] = 34, [26] =5}
    print("tbl 最大值:", table_maxn(tbl))
    print("tbl 长度 ", #tbl)

    执行以上代码输出结果为:

    tbl 最大值:    34
    tbl 长度     3

     

    注意:

    当我们获取 table 的长度的时候无论是使用 # 还是 table.getn 其都会在索引中断的地方停止计数,而导致无法正确取得 table 的长度。

    可以使用以下方法来代替:

    function table_leng(t)
      local leng=0
      for k, v in pairs(t) do
        leng=leng+1
      end
      return leng;
    end
  • 相关阅读:
    三种常用的迭代搜索优化方法
    三种常用的迭代搜索优化方法
    颜色空间总结
    颜色空间总结
    卷积神经网络(CNN)
    卷积神经网络(CNN)
    在沉睡中站立起来
    在沉睡中站立起来
    Terence’s Stuff: Why do we do research?
    Terence’s Stuff: Why do we do research?
  • 原文地址:https://www.cnblogs.com/cdyboke/p/7748249.html
Copyright © 2011-2022 走看看