好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > Lua的table庫函數insert、remove、concat、sort詳細介紹

Lua的table庫函數insert、remove、concat、sort詳細介紹

熱門標簽:百度地圖標注早餐區域 漳州智云呼電話機器人 冀州市地圖標注 清朝地圖標注哈爾濱 地圖標注大廈 怎么去除地圖標注 新岸線智能電銷機器人 武漢外呼防封系統多少錢 個人怎么在地圖標注需要的店鋪

函數列表:

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

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

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

復制代碼 代碼如下:

        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 內部會維護一個變量記錄遍歷的位置,remove 掉第三個數字 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 循環里修改 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 的數組部分拼接成一個字符串,中間用 seq 分隔。 
    lua 中字符串的存儲方式與 C 不一樣,lua 中的每個字符串都是單獨的一個拷貝,拼接兩個字符串會產生一個新的拷貝,如果拼接操作特別多,就會影響性能:
 

復制代碼 代碼如下:

        local beginTime = os.clock()
        local str = ""
        for i=1, 30000 do
            str = str .. i
        end
        local endTime = os.clock()
        print(endTime - beginTime)
        -- 消耗 0.613 秒,產生了 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,一次性把字符串拼接出來,只產生了一個字符串拷貝
      

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

復制代碼 代碼如下:

        local function comp(a,b)
            return a = b
        end
        table.sort(t,comp)
        -- 錯誤,可能出現異常: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)
        -- 錯誤,可能出現異常:invalid order function for sorting
        -- 也可能不報這個異常,但結果是錯誤的;
    之所以 a==b 返回true 會引發這些問題,是因為 table.sort 在實現快速排序時沒有做邊界檢測:
        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 (ji) {
            lua_pop(L, 3);
            break;
          }
          set2(L, i, j);
        }
  

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

您可能感興趣的文章:
  • 深入談談lua中神奇的table
  • Lua Table轉C# Dictionary的方法示例
  • Lua中設置table為只讀屬性的方法詳解
  • Lua編程示例(一):select、debug、可變參數、table操作、error
  • 舉例講解Lua中的Table數據結構
  • Lua table中安全移除元素的方法
  • C++遍歷Lua table的方法實例
  • Lua中釋放table占用內存的方法
  • Lua中table的遍歷詳解
  • Lua中獲取table長度問題探討
  • Lua中獲取table長度的方法
  • Lua中table里內嵌table的例子
  • Lua面向對象編程之基礎結構table簡例

標簽:濰坊 天門 天門 德宏 金昌 臺灣 宣城 儋州

巨人網絡通訊聲明:本文標題《Lua的table庫函數insert、remove、concat、sort詳細介紹》,本文關鍵詞  Lua,的,table,庫,函數,insert,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《Lua的table庫函數insert、remove、concat、sort詳細介紹》相關的同類信息!
  • 本頁收集關于Lua的table庫函數insert、remove、concat、sort詳細介紹的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 国产网站| 韩国三级日本三级香港三级黄| 德国性A片一区二区| 看b站直播温莎的软件| 清纯校花被调教高h| 日日麻批免费视频播放40分钟| 欧美精品一区二区三区四区 在线 欧美精品AV二区不卡老司机福利 高清国产一级做a爱片在线看免费 | 全免费A级毛片免费看表情包桃豆| 国产成人99精品免费视频麻豆| 胸前两个小兔子又立起来了| 久久久久激情免费观看| 久久精品日韩免费观看频道| 亚洲午夜AV无码专区在线播放| 77成人影视| 医婿叶凡唐若雪大结局| 小腹被灌满精子隆起被堵住| 91??丨PORNY丨中文| 嗯灬啊灬把腿张开灬A片动漫| 国产香蕉91tv永久在线| 台湾妓女A片免费看| 黑人的太大太爽了我受不了了| 在线满18网站观看视频| 国产三级a三级三级| 欧美一级黄色录像片| 毛片123| 无码人妻丰满熟妇啪啪欧美| 中文字幕人妻在线一区| 好大好硬11p| 性欧美18ⅩXOO极品图片| 亚洲精品第一国产麻豆| 被夫上司连续侵犯| 精品国产乱码久久久久久国产自啪 | 丰满的岳坶4中文字幕| 暗交小拗女一区二区| 99久久国产精品久久99蜜覆 | 法国贵妇性猛交BBwBEEG| 美女主播无遮挡免费视频| 双腿放在调教台上调教h视频| a级毛片电影| 欧美一级婬片免费视频1| 两个人免费视频www|