zoukankan      html  css  js  c++  java
  • 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, ","))

    (完)
  • 相关阅读:
    【C/C++】【类和对象】计算类所占的字节数
    【算法】【单调栈】单调栈
    【算法】【字符串】C语言常用库函数实现
    【算法】【字符串】Leetcode哈希表相关高频面试题
    ubuntu20.04安装测试uhttpd
    华为Mate14上安装Ubuntu20.04纪要
    shell判断参数值是否在数组内的方法
    降低PDF质量
    Ubuntu 16.04上安装Global阅读源代码工具
    Linux下好用的屏幕录像软件kazam及截图软件shutter
  • 原文地址:https://www.cnblogs.com/bhlsheji/p/5158744.html
Copyright © 2011-2022 走看看