Lua-표준 라이브러리

Lua 표준 라이브러리는 C API로 직접 구현되고 Lua 프로그래밍 언어로 내장 된 풍부한 기능 세트를 제공합니다. 이러한 라이브러리는 Lua 프로그래밍 언어 내에서 서비스를 제공하며 파일 및 db 작업과 같은 외부 서비스도 제공합니다.

공식 C API에 내장 된 이러한 표준 라이브러리는 별도의 C 모듈로 제공됩니다. 그것은 다음을 포함합니다-

  • 코 루틴 하위 라이브러리를 포함하는 기본 라이브러리
  • 모듈 라이브러리
  • 문자열 조작
  • 테이블 조작
  • 수학 라이브러리
  • 파일 입력 및 출력
  • 운영 체제 시설
  • 디버그 기능

기본 라이브러리

다양한 주제로 튜토리얼 전체에서 기본 라이브러리를 사용했습니다. 다음 표는 관련 페이지의 링크를 제공하고이 Lua 튜토리얼의 다양한 부분에서 다루는 기능을 나열합니다.

Sr. 아니. 도서관 / 방법 및 목적
1

Error Handling

Lua-Error Handling 에서 설명한 것처럼 assert, error와 같은 오류 처리 기능을 포함합니다 .

2

Memory Management

Lua-Garbage Collection에 설명 된대로 가비지 수집과 관련된 자동 메모리 관리 기능을 포함합니다 .

dofile ([filename])

파일을 열고 파일의 내용을 청크로 실행합니다. 매개 변수가 전달되지 않으면이 함수는 표준 입력의 내용을 실행합니다. 오류는 호출자에게 전파됩니다.

4

_G

따라서 글로벌 환경 (즉, _G._G = _G)을 보유하는 글로벌 변수입니다. Lua 자체는이 변수를 사용하지 않습니다.

5

getfenv ([f])

함수에서 사용중인 현재 환경을 반환합니다. f는 Lua 함수 또는 해당 스택 레벨에서 함수를 지정하는 숫자 일 수 있습니다. 레벨 1은 getfenv를 호출하는 함수입니다. 주어진 함수가 Lua 함수가 아니거나 f가 0이면 getfenv는 전역 환경을 반환합니다. f의 기본값은 1입니다.

6

getmetatable (object)

객체에 메타 테이블이 없으면 nil을 반환합니다. 그렇지 않고 객체의 메타 테이블에 "__metatable"필드가 있으면 관련 값을 반환합니다. 그렇지 않으면 주어진 객체의 메타 테이블을 반환합니다.

7

ipairs (t)

이 함수는 테이블의 인덱스와 값을 가져옵니다.

8

load (func [, chunkname])

func 함수를 사용하여 조각을 가져 오는 청크를로드합니다. func에 대한 각 호출은 이전 결과와 연결되는 문자열을 반환해야합니다.

9

loadfile ([filename]))

로드와 유사하지만 파일 이름이 지정되지 않은 경우 파일 파일 이름 또는 표준 입력에서 청크를 가져옵니다.

10

loadstring (string [, chunkname])

load와 비슷하지만 주어진 문자열에서 청크를 가져옵니다.

11

next (table [, index])

프로그램이 테이블의 모든 필드를 순회 할 수 있도록합니다. 첫 번째 인수는 테이블이고 두 ​​번째 인수는이 테이블의 인덱스입니다. next는 테이블의 다음 인덱스와 관련 값을 반환합니다.

12

pairs (t)

실행중인 코 루틴을 일시 중단합니다. 이 메서드에 전달 된 매개 변수는 resume 함수에 대한 추가 반환 값으로 작동합니다.

13

print (...)

실행중인 코 루틴을 일시 중단합니다. 이 메서드에 전달 된 매개 변수는 resume 함수에 대한 추가 반환 값으로 작동합니다.

14

rawequal (v1, v2)

메타 메서드를 호출하지 않고 v1이 v2와 같은지 확인합니다. 부울을 반환합니다.

15

rawget (table, index)

메타 메서드를 호출하지 않고 table [index]의 실제 값을 가져옵니다. 테이블은 테이블이어야합니다. index는 모든 값이 될 수 있습니다.

16

rawset (table, index, value)

메타 메서드를 호출하지 않고 table [index]의 실제 값을 value로 설정합니다. table은 테이블이어야하고 nil과 다른 값을 인덱싱하고 모든 Lua 값을 평가해야합니다. 이 함수는 테이블을 반환합니다.

17

select (index, ...)

index가 숫자이면 인수 번호 index 뒤의 모든 인수를 반환합니다. 그렇지 않으면 index는 문자열 "#"이어야하며 select는 수신 한 추가 인수의 총 수를 반환합니다.

18

setfenv (f, table)

주어진 함수에서 사용할 환경을 설정합니다. f는 Lua 함수 또는 해당 스택 레벨에서 함수를 지정하는 숫자 일 수 있습니다. 레벨 1은 setfenv를 호출하는 함수입니다. setfenv는 주어진 함수를 반환합니다. 특별한 경우, f가 0 일 때 setfenv는 실행중인 스레드의 환경을 변경합니다. 이 경우 setfenv는 값을 반환하지 않습니다.

19

setmetatable (table, metatable)

주어진 테이블에 대한 메타 테이블을 설정합니다. (다른 유형의 메타 테이블은 Lua에서 변경할 수 없으며 C에서만 변경할 수 있습니다.) 메타 테이블이 nil이면 주어진 테이블의 메타 테이블을 제거합니다. 원본 메타 테이블에 "__metatable"필드가 있으면 오류가 발생합니다. 이 함수는 테이블을 반환합니다.

20

tonumber (e [, base])

인수를 숫자로 변환하려고합니다. 인수가 이미 숫자이거나 숫자로 변환 가능한 문자열이면 tonumber는이 숫자를 반환합니다. 그렇지 않으면 nil을 반환합니다.

21

tostring (e)

모든 유형의 인수를 받아 적절한 형식의 문자열로 변환합니다. 숫자 변환 방법을 완전히 제어하려면 string.format을 사용하십시오.

22

type (v)

문자열로 코딩 된 유일한 인수 유형을 반환합니다. 이 함수의 가능한 결과는 "nil"(값 nil이 아닌 문자열), "number", "string", "boolean", "table", "function", "thread"및 "userdata"입니다.

23

unpack (list [, i [, j]])

주어진 테이블에서 요소를 반환합니다.

24

_VERSION

현재 인터프리터 버전을 포함하는 문자열을 보유하는 전역 변수 (함수 아님). 이 변수의 현재 내용은 "Lua 5.1"입니다.

25

Coroutines

루아- 코 루틴에 설명 된 코 루틴 조작 함수를 포함합니다 .

모듈 라이브러리

모듈 라이브러리는 Lua에서 모듈을로드하기위한 기본 기능을 제공합니다. 전역 환경에서 직접 하나의 기능을 내 보냅니다 : require. 다른 모든 것은 테이블 패키지로 내보내집니다. 모듈 라이브러리에 대한 자세한 내용은 이전 장 Lua-모듈 자습서 에서 설명합니다 .

문자열 조작

Lua는 다양한 문자열 조작 기능을 제공합니다. 이전 Lua-Strings 튜토리얼에서 이에 대해 자세히 다룹니다.

테이블 조작

Lua는 거의 모든 작업에서 테이블에 의존합니다. 이전 Lua-Tables 자습서에서 이에 대해 자세히 다룹니다.

파일 입력 및 출력

우리는 종종 프로그래밍에 데이터 저장 시설이 필요하며 이것은 Lua의 파일 I / O를위한 표준 라이브러리 함수에 의해 제공됩니다. 이는 이전 Lua-파일 I / O 튜토리얼 에서 논의되었습니다 .

디버그 기능

Lua는 자체 디버거를 생성 할 수 있도록 모든 기본 함수를 제공하는 디버그 라이브러리를 제공합니다. 이는 이전 Lua-디버깅 튜토리얼 에서 논의되었습니다 .