• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            focus on linux, c/c++, lua

            c中遍歷lua表結(jié)構(gòu)

            // 進(jìn)行下面步驟前先將 table 壓入棧頂 
             int nIndex = lua_gettop( pLua );  // 取 table 索引值 
             lua_pushnil( pLua );  // nil 入棧作為初始 key 
             while0 != lua_next( pLua, nIndex ) ) 
             

                 
            // 現(xiàn)在棧頂(-1)是 value,-2 位置是對應(yīng)的 key 
                 
            // 這里可以判斷 key 是什么并且對 value 進(jìn)行各種處理 
                 lua_pop( pLua, 1 );  // 彈出 value,讓 key 留在棧頂 
             }
             
             
            // 現(xiàn)在棧頂是 table

            lua_next() 這個函數(shù)的工作過程是:
            1) 先從棧頂彈出一個 key
            2) 從棧指定位置的 table 里取下一對 key-value,先將 key 入棧再將 value 入棧
            3) 如果第 2 步成功則返回非 0 值,否則返回 0,并且不向棧中壓入任何值

            第 2 步中從 table 里取出所謂“下一對 key-value”是相對于第 1 步中彈出的 key 的。table 里第一對 key-value 的前面沒有數(shù)據(jù),所以先用 lua_pushnil() 壓入一個 nil 充當(dāng)初始 key。

            注意開始的時候先用 lua_gettop() 取了一下 table 在棧中的正索引(前面說過了,在進(jìn)行這個 lua_next() 過程之前先將 table 入棧,所以棧大小就是 table 的正索引),后面的 lua_next() 過程中不斷的有元素出入棧,所以使用正索引來定位 table 比較方便。

            到了 table 中已經(jīng)沒有 key-value 對時,lua_next() 先彈出最后一個 key,然后發(fā)現(xiàn)已經(jīng)沒有數(shù)據(jù)了會返回 0,while 循環(huán)結(jié)束。所以這個 lua_next() 過程結(jié)束以后 table 就又位于棧頂了。


            問題概要: 用lua寫了個函數(shù),返回的是一個表.需要在C里對返回的表里元素做二次處理.
            在C里我們可以通過lua_gettable()或者lua_rawget()來獲取表里元素值,但使用這兩個接口的前提是你得知道key,它才能給你value. 當(dāng)然對于順序下標(biāo)倒無所謂,但恰巧這次我用到的是關(guān)聯(lián)數(shù)組,下標(biāo)是無規(guī)則字符串.這時候如何遍歷出表里元素就是個問題.
            lua_next()就成了比較合適的選擇.

            上圖對簡單的表遍歷做了介紹, 但事實(shí)上的情況是我返回了一個二維表,如果你了解了lua_next()的處理過程,那下面的代碼看起來就沒什么問題了.
                   t_idx = lua_gettop(L);
                   lua_pushnil(L);
                  
                   while (lua_next(L, t_idx))
                   {
                          printf("============================\n");
                          it_idx = lua_gettop(L);
                          lua_pushnil(L);
                          while(lua_next(L, it_idx))
                          {
                                 printf("%s\n", lua_tostring(L, -1));
                                 lua_pop(L, 1);
                          }
                          lua_pop(L, 1);
                   }

            posted on 2010-08-10 15:14 zuhd 閱讀(2119) 評論(0)  編輯 收藏 引用 所屬分類: lua

            国产精品青草久久久久福利99| 欧美日韩精品久久久久| 91精品国产乱码久久久久久| 久久天天躁狠狠躁夜夜avapp| 国产亚洲综合久久系列| 久久久久久狠狠丁香| 一本久久综合亚洲鲁鲁五月天亚洲欧美一区二区 | 久久久久久久人妻无码中文字幕爆| 亚洲一区二区三区日本久久九| 久久这里有精品视频| 久久综合给合久久狠狠狠97色69| 亚洲国产二区三区久久| 模特私拍国产精品久久| 99久久99久久| 久久精品国产乱子伦| 久久99精品久久久久久噜噜| 蜜臀久久99精品久久久久久小说| 91麻豆精品国产91久久久久久| 热99RE久久精品这里都是精品免费 | 午夜不卡888久久| 国产精品久久久99| 777午夜精品久久av蜜臀| 国产精品99久久久久久www| 日韩人妻无码一区二区三区久久 | 久久综合给合久久国产免费| 久久精品成人免费国产片小草| 狠狠色丁香婷综合久久| 囯产极品美女高潮无套久久久| 久久99精品久久久久久不卡| 狠狠干狠狠久久| 国产成人精品久久二区二区| 伊人久久大香线蕉av一区| 日韩久久无码免费毛片软件| 99久久精品费精品国产| 韩国三级大全久久网站| 69国产成人综合久久精品| 婷婷久久久亚洲欧洲日产国码AV | 狠狠人妻久久久久久综合| 久久99国产精品久久99| 精品国产91久久久久久久| 久久99国产精品久久99|