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, 둘 다 ab같은 메모리를 참조하십시오. 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. 아니. 방법 및 목적
1

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

주어진 매개 변수를 기반으로 테이블의 문자열을 연결합니다. 자세한 내용은 예를 참조하십시오.

2

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

테이블의 지정된 위치에 값을 삽입합니다.

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