Lua应用——tables应用,查找是否为保留字
生活随笔
收集整理的這篇文章主要介紹了
Lua应用——tables应用,查找是否为保留字
小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.
Lua中的table功能確實(shí)強(qiáng)大。因?yàn)閠able是Lua中的唯一數(shù)據(jù)結(jié)構(gòu)。今天有點(diǎn)暈,少說兩句多拷貝代碼吧。
實(shí)例:
假定你想列出在一段源代碼中出現(xiàn)的所有標(biāo)示符,某種程度上,你需要過濾掉那些語言本身的保留字。一些C程序員喜歡用一個字符串?dāng)?shù)組來表示,將所有的保留字放在數(shù)組中,對每一個標(biāo)示符到這個數(shù)組中查找看是否為保留字,有時候?yàn)榱颂岣卟樵冃?#xff0c;對數(shù)組存儲的時候使用二分查找或者h(yuǎn)ash算法。
Lua中表示這個集合有一個簡單有效的方法,將所有集合中的元素作為下標(biāo)存放在一個table里,下面不需要查找table,只需要測試看對于給定的元素,表的對應(yīng)下標(biāo)的元素值是否為nil。比如:
還可以使用輔助函數(shù)更加清晰的構(gòu)造集合:
function Set (list)local set = {}for _, l in ipairs(list) do set[l] = true endreturn set end reserved = Set{"while", "end", "function", "local", }?
恩,這種方式,用的地方不少哦
轉(zhuǎn)載于:https://www.cnblogs.com/slysky/p/5416419.html
總結(jié)
以上是生活随笔為你收集整理的Lua应用——tables应用,查找是否为保留字的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 重温C# clr 笔记总结
- 下一篇: 迷你DVD管理器项目