表格是唯一的數(shù)據(jù)結(jié)構(gòu)中Lua可以幫助我們創(chuàng)造出不同的類型,如數(shù)組和字典。 Lua使用關(guān)聯(lián)數(shù)組和可不僅數(shù)字,但也有不同的零字符串索引。表格都沒有固定的大小,并根據(jù)需要可以增長。
Lua采用的所有陳述,包括包裝的代表性表。當(dāng)我們訪問一個方法的字符串。格式,這意味著,我們正在訪問的格式化功能的字符串封裝。
表示和用法
表稱為對象和它們既不值,也沒有變。 Lua使用構(gòu)造函數(shù)表達式{}創(chuàng)建一個空表。它是要知道,有保存表的參考和表本身的變量之間沒有固定的關(guān)系。
--simple table value assignment
mytable[1]= "Lua"
--removing reference
mytable = nil
-- lua garbage collection will take care of releasing memory
當(dāng)我們有一個表與集合的元素,如果我們將其指定為b,a和b都指向相同的內(nèi)存。沒有單獨的內(nèi)存單獨分配對b。當(dāng)設(shè)置為無,表將仍然可以訪問到b。當(dāng)沒有引用表,然后在Lua垃圾收集需要清理過程,使這些未引用的內(nèi)存再次被重用。
一個例子如下所示用于說明表的上述特征。
mytable[1]= "Lua"
mytable["wow"] = "Tutorial"
print("mytable Element at index 1 is ", mytable[1])
print("mytable Element at index wow is ", mytable["wow"])
-- alternatetable and mytable refers to same table
alternatetable = mytable
print("alternatetable Element at index 1 is ", alternatetable[1])
print("mytable Element at index wow is ", alternatetable["wow"])
alternatetable["wow"] = "I changed it"
print("mytable Element at index wow is ", mytable["wow"])
-- only variable released and and not table
alternatetable = nil
print("alternatetable is ", alternatetable)
-- mytable is still accessible
print("mytable Element at index wow is ", mytable["wow"])
mytable = nil
print("mytable is ", mytable)
當(dāng)我們運行上面的程序,會得到下面的輸出
表操作
在對表操作內(nèi)置函數(shù)和它們被列于下表中。
讓我們看看上面的函數(shù)一些例子。
表串聯(lián)
我們可以使用concat函數(shù)來連接,如下所示的兩個表。
--concatenate with a character
print("Concatenated string ",table.concat(fruits,", "))
--concatenate fruits based on index
print("Concatenated string ",table.concat(fruits,", ", 2,3))
當(dāng)我們運行上面的程序,會得到下面的輸出
插入和刪除
插入在表中的項目,并除去最常見于表操縱。它下面的解釋。
-- insert a fruit at the end
table.insert(fruits,"mango")
print("Fruit at index 4 is ",fruits[4])
--insert fruit at index 2
table.insert(fruits,2,"grapes")
print("Fruit at index 2 is ",fruits[2])
print("The maximum elements in table is",table.maxn(fruits))
print("The last element is",fruits[5])
table.remove(fruits)
print("The previous last element is",fruits[5])
當(dāng)我們運行上面的程序,會得到下面的輸出
排序表格
排序表通常需要和排序函數(shù)表中的元素按字母順序排序。下圖所示為這方面的一個范例。
當(dāng)我們運行上面的程序,會得到下面的輸出
標(biāo)簽:普洱 荊門 張家界 梧州 三沙 公主嶺 遼寧 永州
巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《詳解Lua中的表的概念及其相關(guān)操作方法》,本文關(guān)鍵詞 詳解,Lua,中的,表,的,概念,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。