判斷方法結(jié)論:
復制代碼 代碼如下:
a={}
if next(a) ~=nil then dosomething end
最近在項目里面大量使用的lua,其中l(wèi)ua的table是lua中重要的數(shù)據(jù)結(jié)構(gòu),可以被用來當做C++中的數(shù)組,vector,map來使用。
如何判斷l(xiāng)ua中的table是否是空的table呢?
一開始我沒動腦子,是這樣寫的:
復制代碼 代碼如下:
a={}
if a ==nil then dosomething end
這個方法錯誤是顯而易見的,在lua中a其實是一個指針,指向了table的結(jié)構(gòu),所以這個方法其實是比較地址是否為空,顯然錯了。
之后我改進了下,代碼如下:
復制代碼 代碼如下:
a={}
if a=={} then dosomething end
仔細一看上面的改進,相當于沒改,這里的a指針比較的還是一個匿名的地址,肯定是false。
之后我這樣想,空table的size肯定為0,那我直接判斷表的大小不就完了嘛,于是我借助#操作符,代碼改進為:
復制代碼 代碼如下:
a={}
if #a==0 then dosomething end
但是問題來了,#操作符要求table中的項都不為nil,悲??!之后我想到了table.maxn內(nèi)置函數(shù),于是代碼繼續(xù)改成:
復制代碼 代碼如下:
a={}
if table.maxn(a) == 0 then dosomething end
不容易啊,程序可以跑了,但是查閱了下相關(guān)資料,maxn函數(shù)是根據(jù)每一項的hash來判斷的,這樣寫代碼也很保險,除非你的table是全數(shù)字的鍵。
最后才想起用泛型方法遍歷一個table時使用的內(nèi)置next函數(shù),代碼改進如下:
復制代碼 代碼如下:
a={}
if next(a) ~=nil then dosomething end
您可能感興趣的文章:- Lua的table庫函數(shù)insert、remove、concat、sort詳細介紹
- Lua中table的幾種構(gòu)造方式詳解
- Lua中對table排序?qū)嵗?/li>
- Lua中遍歷數(shù)組和table的4種方法
- Lua中的table學習筆記
- Lua中使用table.concat連接大量字符串實例
- Lua中的table淺析
- Lua中使用table實現(xiàn)的其它5種數(shù)據(jù)結(jié)構(gòu)
- 獲取Lua表結(jié)構(gòu)(table)數(shù)據(jù)實例
- 深入談?wù)刲ua中神奇的table