Lua - Таблицы

Введение

Таблицы - единственная структура данных, доступная в Lua, которая помогает нам создавать различные типы, такие как массивы и словари. Lua использует ассоциативные массивы, которые можно индексировать не только числами, но и строками, кроме nil. Таблицы не имеют фиксированного размера и могут увеличиваться по мере необходимости.

Lua использует таблицы во всех представлениях, включая представление пакетов. Когда мы обращаемся к методу string.format, это означает, что мы обращаемся к функции форматирования, доступной в строковом пакете.

Представление и использование

Таблицы называются объектами, и они не являются ни значениями, ни переменными. Lua использует выражение конструктора {} для создания пустой таблицы. Следует знать, что не существует фиксированной связи между переменной, содержащей ссылку на таблицу, и самой таблицей.

--sample table initialization
mytable = {}

--simple table value assignment
mytable[1]= "Lua"

--removing reference
mytable = nil

-- lua garbage collection will take care of releasing memory

Когда у нас есть стол a с набором элементов и если мы назначим его b, и то и другое a и bотносятся к той же памяти. Отдельная память для b не выделяется. Когда a установлено в nil, таблица будет по-прежнему доступна для b. Когда нет ссылки на таблицу, сборка мусора в Lua заботится о процессе очистки, чтобы снова использовать эту память, на которую нет ссылок.

Ниже показан пример для объяснения вышеупомянутых функций таблиц.

-- Simple empty table
mytable = {}
print("Type of mytable is ",type(mytable))

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("alternatetable 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)

Когда мы запустим вышеуказанную программу, мы получим следующий результат -

Type of mytable is 	table
mytable Element at index 1 is 	Lua
mytable Element at index wow is 	Tutorial
alternatetable Element at index 1 is 	Lua
alternatetable Element at index wow is 	Tutorial
mytable Element at index wow is 	I changed it
alternatetable is 	nil
mytable Element at index wow is 	I changed it
mytable is 	nil

Управление таблицей

Есть встроенные функции для работы с таблицами, и они перечислены в следующей таблице.

Sr. No. Метод и цель
1

table.concat (table [, sep [, i [, j]]])

Объединяет строки в таблицах на основе заданных параметров. См. Пример для подробностей.

2

table.insert (table, [pos,] value)

Вставляет значение в таблицу в указанной позиции.

3

table.maxn (table)

Возвращает наибольший числовой индекс.

4

table.remove (table [, pos])

Удаляет значение из таблицы.

5

table.sort (table [, comp])

Сортирует таблицу на основе необязательного аргумента компаратора.

Давайте посмотрим некоторые примеры вышеуказанных функций.

Объединение таблиц

Мы можем использовать функцию concat для объединения двух таблиц, как показано ниже -

fruits = {"banana","orange","apple"}

-- returns concatenated string of table
print("Concatenated string ",table.concat(fruits))

--concatenate with a character
print("Concatenated string ",table.concat(fruits,", "))

--concatenate fruits based on index
print("Concatenated string ",table.concat(fruits,", ", 2,3))

Когда мы запустим вышеуказанную программу, мы получим следующий результат -

Concatenated string 	bananaorangeapple
Concatenated string 	banana, orange, apple
Concatenated string 	orange, apple

Вставить и удалить

Вставка и удаление элементов в таблицах чаще всего используются при работе с таблицами. Это объясняется ниже.

fruits = {"banana","orange","apple"}

-- 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])

Когда мы запустим вышеуказанную программу, мы получим следующий результат -

Fruit at index 4 is 	mango
Fruit at index 2 is 	grapes
The maximum elements in table is	5
The last element is	mango
The previous last element is	nil

Сортировочные таблицы

Нам часто требуется отсортировать таблицу в определенном порядке. Функции сортировки сортируют элементы в таблице по алфавиту. Пример для этого показан ниже.

fruits = {"banana","orange","apple","grapes"}

for k,v in ipairs(fruits) do
   print(k,v)
end

table.sort(fruits)
print("sorted table")

for k,v in ipairs(fruits) do
   print(k,v)
end

Когда мы запустим вышеуказанную программу, мы получим следующий результат -

1	banana
2	orange
3	apple
4	grapes
sorted table
1	apple
2	banana
3	grapes
4	orange