Lua 通過一個虛擬棧與 C 的交互,正數(shù)索引自底向上取值,負(fù)數(shù)索引自頂向下取值。
Lua 中的 Table(表)結(jié)構(gòu)可以使用任何數(shù)據(jù)作為 key 進(jìn)行取值。使用 C API 訪問 Table 中的元素有兩種方法:
lua_getglobal(L, t);
lua_getfield(L, -1, k);
在結(jié)束時,棧上的情況均為:棧頂為 t[k],次頂元素為 Table 類型的 t。第二種方法其實(shí)是第一種方法在「key 為字符串」時的特殊寫法。
C API 遍歷 Table
lua_next 函數(shù)針對 -2 處(參數(shù)指定)的 Table 進(jìn)行遍歷。彈出 -1 處(棧頂)的值作為上一個 key(為 nil 時視為請求首個 key),壓入 Table 中的下一個 key 和 value。返回值表示是否存在下一個 key。
另外在循環(huán)中處理值時要記得隨時清理?xiàng)?,否則 Table 就不在 -2 了。(也可以考慮在 lua_getglobal 后用 lua_gettop 存下 Table 的正數(shù)索引。)
雖然這是手冊中記載的遍歷方法,但這種方法在遍歷時并沒有一定的遍歷順序,于是便又有了下面的方法。
用整數(shù) Key 進(jìn)行并不那么完美的遍歷
這種方法無視了非整數(shù) key,但可以保證遍歷順序。如果只關(guān)注整數(shù) key,可以考慮用這種遍歷方法 :)
標(biāo)簽:儋州 天門 天門 金昌 德宏 宣城 臺灣 濰坊
巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Lua 學(xué)習(xí)筆記之C API 遍歷 Table實(shí)現(xiàn)代碼》,本文關(guān)鍵詞 Lua,學(xué)習(xí),筆記,之,API,遍歷,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。