Lua-標準ライブラリ
Lua標準ライブラリは、C APIで直接実装され、Luaプログラミング言語で組み込まれている豊富な関数セットを提供します。これらのライブラリは、Luaプログラミング言語内だけでなく、ファイルやデータベース操作などの外部サービスも提供します。
公式のCAPIに組み込まれているこれらの標準ライブラリは、個別のCモジュールとして提供されます。以下が含まれます-
- コルーチンサブライブラリを含む基本ライブラリ
- モジュールライブラリ
- 文字列操作
- テーブル操作
- 数学ライブラリ
- ファイルの入力と出力
- オペレーティングシステム設備
- デバッグ機能
基本ライブラリ
チュートリアル全体を通して、さまざまなトピックの下で基本ライブラリを使用しました。次の表に、関連ページのリンクを示し、このLuaチュートリアルのさまざまな部分でカバーされている機能を示します。
シニア番号 | ライブラリ/方法と目的 |
---|---|
1 | Error Handling で説明したようにエラー処理のassertのような機能、エラーが含まれていますエラー処理-ルア。 |
2 | Memory Management で説明したように、ガベージコレクションに関連した自動メモリ管理機能が含まれていますルア-ガベージコレクション。 |
3 | 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])) loadと似ていますが、ファイル名が指定されていない場合は、ファイルfilenameまたは標準入力からチャンクを取得します。 |
10 | loadstring (string [, chunkname]) loadと似ていますが、指定された文字列からチャンクを取得します。 |
11 | next (table [, index]) プログラムがテーブルのすべてのフィールドをトラバースできるようにします。その最初の引数はテーブルであり、その2番目の引数はこのテーブルのインデックスです。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が数値の場合、引数numberindexの後のすべての引数を返します。それ以外の場合、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 現在のインタプリタバージョンを含む文字列を保持するグローバル変数(関数ではありません)。この変数の現在の内容は「Lua5.1」です。 |
25 | Coroutines Lua-Coroutinesで説明されているコルーチン操作関数が含まれています。 |
モジュールライブラリ
モジュールライブラリは、Luaにモジュールをロードするための基本的な機能を提供します。1つの関数をグローバル環境に直接エクスポートします:require。それ以外はすべてテーブルパッケージでエクスポートされます。モジュールライブラリの詳細は、前の章「Lua-モジュールチュートリアル」で説明されています。
文字列操作
Luaは、豊富な文字列操作関数のセットを提供します。以前のLua-Stringsチュートリアルでは、これについて詳しく説明しています。
テーブル操作
Luaは、操作のほぼすべてのビットでテーブルに依存しています。以前のLua-Tablesチュートリアルでは、これについて詳しく説明しています。
ファイルの入力と出力
プログラミングではデータストレージ機能が必要になることがよくあります。これは、LuaのファイルI / O用の標準ライブラリ関数によって提供されます。これについては、以前のLua-ファイルI / Oチュートリアルで説明しています。
デバッグ機能
Luaは、独自のデバッガーを作成するためのすべてのプリミティブ関数を提供するデバッグライブラリを提供します。これについては、以前のLua-デバッグチュートリアルで説明しています。