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