• lua的table库中经常使用的函数


    lua提供了一些辅助函数来操作table。

    比如,从list中insert和remove元素,对array的元素进行sort。或者concatenate数组中的全部strings。以下就具体地解说这些方法。


    insert and remove
    table.insert将一个元素插入到指定位置。比如:
    t = {1, 2, 3}
    table.insert(t, 1, 4}
    t的结果将是{4, 1, 2, 3}
    insert的第二个參数是能够省略的。这样就会插入到数组的最后,从而不必移动其它元素。相同地。table.remove是从数组中移除(并返回)一个元素,table.remove(t,1)将移除t中下标是1的元素,假设不指定移除位置,则移除最后一个。

    通过insert,remove方法,就能非常直接的地实现stacks。queues, double queues. push操作就相当于table.insert(t, x), 而pop操作就相当于table.remove(t)。比如定义一个栈:
    stack = {}
    function stack:push(x)
         table.insert(self, x)
    end

    function stack:pop()
         table.remove(self)
    end

    sort
    还有一个实用的函数是sort,对数组进行排序,假设没有提供排序函数,默认是<操作。

    人们范的普遍的错误是尝试对table的key进行排序。

    在table里,全部key组成个集合,绝壁没有不论什么顺序。

    假设你要对他们排序。首先要将他们复制到一个数组里。然后在进行sort。假如我们有一个table,想要以排序后的key的顺序进行迭代,我们就能够写过这种迭代器:

    function pairsByKeys(t, f)
         local a = {}
         for k in pairs(t) do a[#a+1] = k end
         table.sort(a, f)
         local i = 0
         return function()
              i = i + 1
              return a[i], t[a[i]]
         end
    end

    concatenation
    给定的table,全部的元素是string或是number,将返回table[i]..sep..table[i+1] ··· sep..table[j],分隔符默认是空字符串。i默认是1, j默认是表的长度。假设i > j, 则返回空字符串。比如:

    spring = {"春林渐盛", "春水初生", "春风十里不如你"}
    print(table.concat(spring, ","))

    (完)
  • 相关阅读:
    解决SecureCRT中文显示乱码
    最新ubuntu10.10更新源
    向linux内核添加系统调用新老内核比较
    Field requires API level 5 (current min is 1) 问题的解决
    ubuntu 搜索文件方法(find命令)
    ubuntu12.04终端全屏
    .classpath 文件中的excluding属性
    eclipse中的.project 和 .classpath文件的具体作用
    Windows Mobile项目编译很慢情况的解决(VS2008)
    windowsphone7高级编程中提到的地址
  • 原文地址:https://www.cnblogs.com/bhlsheji/p/5158744.html
Copyright © 2020-2023  润新知