Lua 學(xué)習(xí)筆記之C API 遍歷 Table實(shí)現(xiàn)代碼
Lua 通過一個虛擬棧與 C 的交互,正數(shù)索引自底向上取值,負(fù)數(shù)索引自頂向下取值。
Lua 中的 Table(表)結(jié)構(gòu)可以使用任何數(shù)據(jù)作為 key 進(jìn)行取值。使用 C API 訪問 Table 中的元素有兩種方法:
lua_getglobal(L, t);
lua_pushinteger(L, k); -- 這里可以換成其它類型的 lua_pushXXXX(L, k) 壓數(shù)據(jù)到棧頂作key
lua_gettable(L, -2);
lua_getglobal(L, t);
lua_getfield(L, -1, k);
在結(jié)束時,棧上的情況均為:棧頂為 t[k],次頂元素為 Table 類型的 t。第二種方法其實(shí)是第一種方法在「key 為字符串」時的特殊寫法。
C API 遍歷 Table
lua_getglobal(L, t);
lua_pushnil(L);
while (lua_next(L, -2)) {
/* 此時棧上 -1 處為 value, -2 處為 key */
lua_pop(L, 1);
}
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)行并不那么完美的遍歷
lua_getglobal(L, t);
len = lua_objlen(L, -1);
for (i = 1; i <= len; i++) {
lua_pushinteger(L, i);
lua_gettable(L, -2);
/* 此時棧頂即為 t[i] 元素 */
lua_pop(L, 1);
}
這種方法無視了非整數(shù) key,但可以保證遍歷順序。如果只關(guān)注整數(shù) key,可以考慮用這種遍歷方法 :)
相關(guān)文章
Lua中的閉合函數(shù)、非全局函數(shù)與函數(shù)的尾調(diào)用詳解
這篇文章主要介紹了Lua中的閉合函數(shù)、非全局函數(shù)與函數(shù)的尾調(diào)用詳解,本文對這2種函數(shù)和尾調(diào)用做了深入研究,需要的朋友可以參考下2014-09-09Lua中類的實(shí)現(xiàn)原理探討(Lua中實(shí)現(xiàn)類的方法)
這篇文章主要介紹了Lua中類的實(shí)現(xiàn)原理探討(Lua中實(shí)現(xiàn)類的方法),本文同時講解了metatable、元方法等內(nèi)容,需要的朋友可以參考下2014-10-10分析Lua觀察者模式最佳實(shí)踐之構(gòu)建事件分發(fā)系統(tǒng)
當(dāng)對象間存在一對多關(guān)系時,則使用觀察者模式(Observer Pattern)。比如,當(dāng)一個對象被修改時,則會自動通知依賴它的對象。觀察者模式屬于行為型模式2021-06-06