c++遍歷lua table示例
更新時(shí)間:2014年04月30日 10:08:39 作者:
這篇文章主要介紹了c++遍歷lua table示例,需要的朋友可以參考下
c/c++從棧上獲取Lua壓棧過來的table數(shù)據(jù)
復(fù)制代碼 代碼如下:
map<string,string> traverse_table(lua_State *L, int index)
{
map<string,string> data;
lua_pushnil(L);
// 現(xiàn)在的棧:-1 => nil; index => table
index = index - 1;
while (lua_next(L, index))
{
// 現(xiàn)在的棧:-1 => value; -2 => key; index => table
// 拷貝一份 key 到棧頂,然后對(duì)它做 lua_tostring 就不會(huì)改變?cè)嫉?key 值了
lua_pushvalue(L, -2);
// 現(xiàn)在的棧:-1 => key; -2 => value; -3 => key; index => table
const char* key = lua_tostring(L, -1);
const char* value = lua_tostring(L, -2);
data[key]=value;
// 彈出 value 和拷貝的 key,留下原始的 key 作為下一次 lua_next 的參數(shù)
lua_pop(L, 2);
// 現(xiàn)在的棧:-1 => key; index => table
}
// 現(xiàn)在的棧:index => table (最后 lua_next 返回 0 的時(shí)候它已經(jīng)把上一次留下的 key 給彈出了)
// 所以棧已經(jīng)恢復(fù)到進(jìn)入這個(gè)函數(shù)時(shí)的狀態(tài)
return data;
}
您可能感興趣的文章:
相關(guān)文章
詳解C++的靜態(tài)內(nèi)存分配與動(dòng)態(tài)內(nèi)存分配
內(nèi)存分配 (Memory Allocation) 是指為計(jì)算機(jī)程序或服務(wù)分配物理內(nèi)存空間或虛擬內(nèi)存空間的一個(gè)過程,本文主要介紹了C++的靜態(tài)內(nèi)存分配與動(dòng)態(tài)內(nèi)存分配,感興趣的同學(xué)可以參考閱讀2023-06-06C語言實(shí)現(xiàn)簡(jiǎn)單的井字棋游戲
這篇文章主要為大家詳細(xì)介紹了C語言實(shí)現(xiàn)簡(jiǎn)單的井字棋游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-04-04C++ OpenCV實(shí)現(xiàn)像素畫的示例代碼
這篇文章主要介紹了通過OpenCV進(jìn)行圖片像素的變化,從而形成像素畫效果的功能。文中的示例代碼講解詳細(xì),感興趣的小伙伴可以動(dòng)手試一試2022-01-01C語言三個(gè)函數(shù)的模擬實(shí)現(xiàn)詳解
這篇文章主要為大家詳細(xì)介紹了C語言三個(gè)函數(shù)的模擬實(shí)現(xiàn),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助2022-03-03