一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

腳本之家,腳本語言編程技術(shù)及教程分享平臺!
分類導(dǎo)航

Python|VBS|Ruby|Lua|perl|VBA|Golang|PowerShell|Erlang|autoit|Dos|bat|

服務(wù)器之家 - 腳本之家 - Lua - Lua的table庫函數(shù)insert、remove、concat、sort詳細介紹

Lua的table庫函數(shù)insert、remove、concat、sort詳細介紹

2020-04-28 10:15腳本之家 Lua

這篇文章主要介紹了Lua的table庫函數(shù)insert、remove、concat、sort詳細介紹,本文分別給出了這幾個函數(shù)的使用實例,需要的朋友可以參考下

函數(shù)列表:

table.insert(table,[ pos,] value)
table.remove(table[, pos])
table.concat(table[, sep[, i[, j]]])
table.sort(table[, comp])

1. insert 和 remove 只能用于數(shù)組元素的插入和移出, 進行插入和移出時,會將后面的元素對齊起來。

    所以在 for 循環(huán)中進行 insert 和 remove 的時候要注意插入和移除時是否漏掉了某些項:
 

復(fù)制代碼 代碼如下:

        local t = {1,2,3,3,5,3,6}
        for i,v in ipairs(t) do
            if v == 3 then
                table.remove(t,i)
            end
        end
        -- 錯誤,第四個 3 沒有被移除,ipairs 內(nèi)部會維護一個變量記錄遍歷的位置,remove 掉第三個數(shù)字 3 之后,ipairs 下一個返回的值是 5 而不是 3
       
        local t = {1,2,3,3,5,3,6}
        for i=1, #t do
            if t[i] == 3 then
                table.remove(t,i)
                i = i-1
            end
        end
        -- 錯誤,i=i-1 這段代碼沒有用,i 的值始終是從 1 到 #t,for 循環(huán)里修改 i 的值不起作用
       
        local t = {1,2,3,3,5,3,6}
        for i=#t, 1, -1 do
            if t[i] == 3 then
                table.remove(t,i)
            end
        end
        -- 正確,從后往前遍歷
       
        local t = {1,2,3,3,5,3,6}
        local i = 1
        while t[i] do
            if t[i] == 3 then
                table.remove(t,i)
            else
                i = i+1
            end
        end
        -- 正確,自己控制 i 的值是否增加
    

 

   2. concat 可以將 table 的數(shù)組部分拼接成一個字符串,中間用 seq 分隔。 
    lua 中字符串的存儲方式與 C 不一樣,lua 中的每個字符串都是單獨的一個拷貝,拼接兩個字符串會產(chǎn)生一個新的拷貝,如果拼接操作特別多,就會影響性能:
 

復(fù)制代碼 代碼如下:


        local beginTime = os.clock()
        local str = ""
        for i=1, 30000 do
            str = str .. i
        end
        local endTime = os.clock()
        print(endTime - beginTime)
        -- 消耗 0.613 秒,產(chǎn)生了 30000 個字符串拷貝,但只有最后一個是有用的

 

        local beginTime = os.clock()
        local t = {}
        for i=1, 30000 do
            t[i] = i
        end
        local str = table.concat(t, "")
        local endTime = os.clock()
        print(endTime - beginTime)
        -- 消耗 0.024 秒,利用 concat,一次性把字符串拼接出來,只產(chǎn)生了一個字符串拷貝
      

 

3. sort 可以將 table 數(shù)組部分的元素進行排序,需要提供 comp 函數(shù),comp(a, b) 如果 a 應(yīng)該排到 b 前面,則 comp 要返回 true 。    
    注意,對于 a==b 的情況,一定要返回 false :
 

復(fù)制代碼 代碼如下:

        local function comp(a,b)
            return a <= b
        end
        table.sort(t,comp)
        -- 錯誤,可能出現(xiàn)異常:attempt to compare number with nil
       
        local function comp(a,b)
            if a == nil or b == nil then
                return false
            end
            return a <= b
        end
        table.sort(t,comp)
        -- 錯誤,可能出現(xiàn)異常:invalid order function for sorting
        -- 也可能不報這個異常,但結(jié)果是錯誤的;
    之所以 a==b 返回true 會引發(fā)這些問題,是因為 table.sort 在實現(xiàn)快速排序時沒有做邊界檢測:
        for (;;) {
          while (lua_rawgeti(L, 1, ++i), sort_comp(L, -1, -2)) {  // 未檢測邊界, i 會一直增加
            if (i>=u) luaL_error(L, "invalid order function for sorting");
            lua_pop(L, 1);
          }
          while (lua_rawgeti(L, 1, --j), sort_comp(L, -3, -1)) {  // 未檢測邊界, j 會一直減少
            if (j<=l) luaL_error(L, "invalid order function for sorting");
            lua_pop(L, 1);
          }
          if (j<i) {
            lua_pop(L, 3);
            break;
          }
          set2(L, i, j);
        }
  


    看以上代碼,如果 a==b 時返回 true 且邊界上的幾個值是相等的話, sort_comp 就無法阻止 i 繼續(xù)增長,直到超出邊界引發(fā)異常 attempt to compare number with nil;即使我們對 a 和 b 進行非空判斷,也會因為 i 超過邊界而引發(fā)異常 invalid order function for sorting
    快速排序是什么,lua 如何實現(xiàn)快速排序,可以參考 lua 源碼中的描述,這里不多介紹;

 

延伸 · 閱讀

精彩推薦
  • LuaLua中table庫函數(shù)方法介紹

    Lua中table庫函數(shù)方法介紹

    這篇文章主要介紹了Lua中table庫函數(shù)方法介紹,本文講解了concat、insert、maxn、remove、sort、foreachi等方法,需要的朋友可以參考下 ...

    腳本之家2502020-04-17
  • LuaLua中的元方法__newindex詳解

    Lua中的元方法__newindex詳解

    這篇文章主要介紹了Lua中的元方法__newindex詳解,本文講解了查詢與更新、監(jiān)控賦值、通過table給另一個table賦值等內(nèi)容,需要的朋友可以參考下 ...

    笨木頭8872020-04-09
  • LuaLua實現(xiàn)__add方法重載示例

    Lua實現(xiàn)__add方法重載示例

    這篇文章主要介紹了Lua實現(xiàn)__add方法重載示例,本文直接給出實現(xiàn)代碼,需要的朋友可以參考下 ...

    腳本之家7452020-04-24
  • LuaLua教程(二):基礎(chǔ)知識、類型與值介紹

    Lua教程(二):基礎(chǔ)知識、類型與值介紹

    這篇文章主要介紹了Lua教程(二):基礎(chǔ)知識、類型與值介紹,本文講解了Hello World程序、代碼規(guī)范、全局變量、類型與值等內(nèi)容,需要的朋友可以參考下 ...

    腳本之家5922020-04-28
  • LuaLua和C語言的交互詳解

    Lua和C語言的交互詳解

    這篇文章主要介紹了Lua和C語言的交互詳解,Lua和C語言通過棧完成交互,本文結(jié)合代碼實例詳細講解了交互的方法,需要的朋友可以參考下 ...

    果凍想3702020-04-14
  • LuaLua中計算、執(zhí)行字符串中Lua代碼的方法

    Lua中計算、執(zhí)行字符串中Lua代碼的方法

    這篇文章主要介紹了Lua中計算、執(zhí)行字符串中Lua代碼的方法,類似JavaScript中eval函數(shù)的功能,在Lua中也可以實現(xiàn),需要的朋友可以參考下 ...

    腳本之家6322020-04-30
  • LuaLua簡介、編譯安裝教程及變量等語法介紹

    Lua簡介、編譯安裝教程及變量等語法介紹

    這篇文章主要介紹了Lua簡介、編譯安裝教程及變量等語法介紹,本文同時講解了lua注釋語法、Lua命令行方式等內(nèi)容,需要的朋友可以參考下 ...

    junjie3632020-04-14
  • Lua深入探究Lua中的解析表達式

    深入探究Lua中的解析表達式

    這篇文章主要介紹了深入探究Lua中的解析表達式,對于其語法部分的說明和示例都超詳細,極力推薦此文!需要的朋友可以參考下 ...

    腳本之家3542020-05-05
主站蜘蛛池模板: 亚洲精品久久麻豆蜜桃 | 色婷婷综合久久久中文字幕 | 性夜夜春夜夜爽AA片A | 日本护士handjob | 性xxx免费视频| 精东影业传媒全部作品 | 精品成人片深夜 | 国产精品一区久久精品 | 教室里的激情电影 | 色人阁图片| 国产欧美va欧美va香蕉在线观看 | 亚洲日本免费 | 久久久久久久久性潮 | 蝴蝶传媒3o45 | 洗濯屋H纯肉动漫在线观看 武侠艳妇屈辱的张开双腿 午夜在线观看免费观看 视频 | 精品久久99麻豆蜜桃666 | 精品国语国产在线对白 | 亚洲熟区 | 午夜福利电影网站鲁片大全 | fistingvideos头交尿眼 | 垫底辣妹免费观看完整版 | 男同激情视频 | 潘金莲西门庆一级淫片aaaaaa | 国产第一综合另类色区奇米 | 亚洲 欧美 中文 日韩欧美 | 久久午夜一区二区 | 嫩草影院永久在线一二三四 | 精品亚洲国产一区二区 | 久久88综合 | 韩日一区二区三区 | 男同gay作爰视频网站 | 亚洲国产精品久久网午夜 | 2023最新伦理片 | 久久99精品涩AV毛片观看 | 欧美bbxx| 国产日韩欧美综合一区二区三区 | 精品国产91久久久久 | 高清毛片aaaaaaaaa片 | 男人捅女人漫画 | 热久久最新网址 | 婷婷伊人综合亚洲综合网 |