Lua中的基本函数库
基本函数库为Lua内置的函数库,不需要额外装载
assert (v [, message])
功能:相当于C的断言,
参数:
v:当表达式v为nil或false将触发错误,
message:发生错误时返回的信息,默认为"assertion failed!"
--------------------------------------------------------------------------------
collectgarbage (opt [, arg])
功能:是垃圾收集器的通用接口,用于操作垃圾收集器
参数:
opt:操作方法标志
"Stop": 停止垃圾收集器
"Restart": 重启垃圾收集器
"Collect": 执行一次全垃圾收集循环
"Count": 返回当前Lua中使用的内存量(以KB为单位)
"Step": 单步执行一个垃圾收集. 步长 "Size" 由参数arg指定 (大型的值需要多步才能完成),如果要准确指定步长,需要多次实验以达最优效果。如果步长完成一次收集循环,将返回True
"Setpause": 设置 arg/100 的值作为暂定收集的时长
"Setstepmul": 设置 arg/100 的值,作为步长的增幅(即新步长=旧步长*arg/100)
--------------------------------------------------------------------------------
dofile (filename)
功能:打开并且执行一个lua块,当忽略参数filename时,将执行标准输入设备(stdin)的内容。返回所有块的返回值。当发生错误时,dofile将错误反射给调用者
注:dofile不能在保护模式下运行
--------------------------------------------------------------------------------
error (message [, level])
功能:终止正在执行的函数,并返回message的内容作为错误信息(error函数永远都不会返回)
通常情况下,error会附加一些错误位置的信息到message头部.
Level参数指示获得错误的位置,
Level=1[默认]:为调用error位置(文件+行号)
Level=2:指出哪个调用error的函数的函数
Level=0:不添加错误位置信息
--------------------------------------------------------------------------------
_G全局环境表(全局变量)
功能:记录全局环境的变量值的表 _G._G = _G
--------------------------------------------------------------------------------
getfenv(f)
功能:返回函数f的当前环境表
参数:f可以为函数或调用栈的级别,级别1[默认]为当前的函数,级别0或其它值将返回全局环境_G
--------------------------------------------------------------------------------
getmetatable(object)
功能:返回指定对象的元表(若object的元表.__metatable项有值,则返回object的元表.__metatable的值),当object没有元表时将返回nil
--------------------------------------------------------------------------------
ipairs (t)
功能:返回三个值 迭代函数、表、0
多用于穷举表的键名和键值对
如:for i,v in ipairs(t) do
end
每次循环将索引赋级i,键值赋给v
注:本函数只能用于以数字索引访问的表 如:t={"1","cash"}
--------------------------------------------------------------------------------
load (func [, chunkname])
功能:装载一个块中的函数,每次调用func将返回一个连接前一结的字串,在块结尾处将返回nil
当没有发生错误时,将返回一个编译完成的块作为函数,否则返回nil加上错误信息,此函数的环境为全局环境
chunkname用于错误和调试信息
--------------------------------------------------------------------------------
loadfile ([filename])
功能:与load类似,但装载的是文件或当没有指定filename时装载标准输入(stdin)的内容
--------------------------------------------------------------------------------
loadstring (string [, chunkname])
功能:与load类似,但装载的内容是一个字串
如:assert(loadstring(s))()
--------------------------------------------------------------------------------
next (table [, index])
功能:允许程序遍历表中的每一个字段,返回下一索引和该索引的值。
参数:table:要遍历的表
index:要返回的索引的前一索中的号,当index为nil[]时,将返回第一个索引的值,当索引号为最后一个索引或表为空时将返回nil
注:可以用next(t)来检测表是否为空(此函数只能用于以数字索引的表与ipairs相类似)
--------------------------------------------------------------------------------
ipairs (t)
功能:返回三个值 next函数、表、0
多用于穷举表的键名和键值对
如:for n,v in pairs(t) do
end
每次循环将索引赋级i,键值赋给v
注:本函数只能用于以键名索引访问的表 如:t={id="1",name="cash"}
--------------------------------------------------------------------------------
pcall (f, arg1, ···)
功能:在保护模式下调用函数(即发生的错误将不会反射给调用者)
当调用函数成功能返回true,失败时将返回false加错误信息
--------------------------------------------------------------------------------
print (···)
功能:简单的以tostring方式格式化输出参数的内容
--------------------------------------------------------------------------------
rawequal (v1, v2)
功能:检测v1是否等于v2,此函数不会调用任何元表的方法
--------------------------------------------------------------------------------
rawget (table, index)
功能:获取表中指定索引的值,此函数不会调用任何元表的方法,成功返回相应的值,当索引不存在时返回nil
注:本函数只能用于以数字索引访问的表 如:t={"1","cash"}
--------------------------------------------------------------------------------
rawset (table, index, value)
功能:设置表中指定索引的值,此函数不会调用任何元表的方法,此函数将返回table
--------------------------------------------------------------------------------
select (index, ···)
功能:当index为数字将返回所有index大于index的参数:如:select(2,"a","b") 返回 "b"
当index为"#",则返回参数的总个数(不包括index)
--------------------------------------------------------------------------------
setfenv (f, table)
功能:设置函数f的环境表为table
参数:f可以为函数或调用栈的级别,级别1[默认]为当前的函数,级别0将设置当前线程的环境表
--------------------------------------------------------------------------------
setmetatable (table, metatable)
功能:为指定的table设置元表metatable,如果metatable为nil则取消table的元表,当metatable有__metatable字段时,将触发错误
注:只能为LUA_TTABLE 表类型指定元表
--------------------------------------------------------------------------------
tonumber (e [, base])
功能:尝试将参数e转换为数字,当不能转换时返回nil
base(2~36)指出参数e当前使用的进制,默认为10进制,如tonumber(11,2)=3
--------------------------------------------------------------------------------
tostirng(e)
功能:将参数e转换为字符串,此函数将会触发元表的__tostring事件
--------------------------------------------------------------------------------
type(v)
功能:返回参数的类型名("nil","number", "string", "boolean", "table", "function", "thread", "userdata")
--------------------------------------------------------------------------------
unpack (list [, i [, j]])
功能:返回指定表的索引的值,i为起始索引,j为结束索引
注:本函数只能用于以数字索引访问的表,否则只会返回nil 如:t={"1","cash"}
--------------------------------------------------------------------------------
_VERSION
功能:返回当前Lua的版本号"Lua 5.1".
--------------------------------------------------------------------------------
xpcall (f, err)
功能:与pcall类似,在保护模式下调用函数(即发生的错误将不会反射给调用者)
但可指定一个新的错误处理函数句柄
当调用函数成功能返回true,失败时将返回false加err返回的结果
assert (v [, message])
功能:相当于C的断言,
参数:
v:当表达式v为nil或false将触发错误,
message:发生错误时返回的信息,默认为"assertion failed!"
--------------------------------------------------------------------------------
collectgarbage (opt [, arg])
功能:是垃圾收集器的通用接口,用于操作垃圾收集器
参数:
opt:操作方法标志
"Stop": 停止垃圾收集器
"Restart": 重启垃圾收集器
"Collect": 执行一次全垃圾收集循环
"Count": 返回当前Lua中使用的内存量(以KB为单位)
"Step": 单步执行一个垃圾收集. 步长 "Size" 由参数arg指定 (大型的值需要多步才能完成),如果要准确指定步长,需要多次实验以达最优效果。如果步长完成一次收集循环,将返回True
"Setpause": 设置 arg/100 的值作为暂定收集的时长
"Setstepmul": 设置 arg/100 的值,作为步长的增幅(即新步长=旧步长*arg/100)
--------------------------------------------------------------------------------
dofile (filename)
功能:打开并且执行一个lua块,当忽略参数filename时,将执行标准输入设备(stdin)的内容。返回所有块的返回值。当发生错误时,dofile将错误反射给调用者
注:dofile不能在保护模式下运行
--------------------------------------------------------------------------------
error (message [, level])
功能:终止正在执行的函数,并返回message的内容作为错误信息(error函数永远都不会返回)
通常情况下,error会附加一些错误位置的信息到message头部.
Level参数指示获得错误的位置,
Level=1[默认]:为调用error位置(文件+行号)
Level=2:指出哪个调用error的函数的函数
Level=0:不添加错误位置信息
--------------------------------------------------------------------------------
_G全局环境表(全局变量)
功能:记录全局环境的变量值的表 _G._G = _G
--------------------------------------------------------------------------------
getfenv(f)
功能:返回函数f的当前环境表
参数:f可以为函数或调用栈的级别,级别1[默认]为当前的函数,级别0或其它值将返回全局环境_G
--------------------------------------------------------------------------------
getmetatable(object)
功能:返回指定对象的元表(若object的元表.__metatable项有值,则返回object的元表.__metatable的值),当object没有元表时将返回nil
--------------------------------------------------------------------------------
ipairs (t)
功能:返回三个值 迭代函数、表、0
多用于穷举表的键名和键值对
如:for i,v in ipairs(t) do
end
每次循环将索引赋级i,键值赋给v
注:本函数只能用于以数字索引访问的表 如:t={"1","cash"}
--------------------------------------------------------------------------------
load (func [, chunkname])
功能:装载一个块中的函数,每次调用func将返回一个连接前一结的字串,在块结尾处将返回nil
当没有发生错误时,将返回一个编译完成的块作为函数,否则返回nil加上错误信息,此函数的环境为全局环境
chunkname用于错误和调试信息
--------------------------------------------------------------------------------
loadfile ([filename])
功能:与load类似,但装载的是文件或当没有指定filename时装载标准输入(stdin)的内容
--------------------------------------------------------------------------------
loadstring (string [, chunkname])
功能:与load类似,但装载的内容是一个字串
如:assert(loadstring(s))()
--------------------------------------------------------------------------------
next (table [, index])
功能:允许程序遍历表中的每一个字段,返回下一索引和该索引的值。
参数:table:要遍历的表
index:要返回的索引的前一索中的号,当index为nil[]时,将返回第一个索引的值,当索引号为最后一个索引或表为空时将返回nil
注:可以用next(t)来检测表是否为空(此函数只能用于以数字索引的表与ipairs相类似)
--------------------------------------------------------------------------------
ipairs (t)
功能:返回三个值 next函数、表、0
多用于穷举表的键名和键值对
如:for n,v in pairs(t) do
end
每次循环将索引赋级i,键值赋给v
注:本函数只能用于以键名索引访问的表 如:t={id="1",name="cash"}
--------------------------------------------------------------------------------
pcall (f, arg1, ···)
功能:在保护模式下调用函数(即发生的错误将不会反射给调用者)
当调用函数成功能返回true,失败时将返回false加错误信息
--------------------------------------------------------------------------------
print (···)
功能:简单的以tostring方式格式化输出参数的内容
--------------------------------------------------------------------------------
rawequal (v1, v2)
功能:检测v1是否等于v2,此函数不会调用任何元表的方法
--------------------------------------------------------------------------------
rawget (table, index)
功能:获取表中指定索引的值,此函数不会调用任何元表的方法,成功返回相应的值,当索引不存在时返回nil
注:本函数只能用于以数字索引访问的表 如:t={"1","cash"}
--------------------------------------------------------------------------------
rawset (table, index, value)
功能:设置表中指定索引的值,此函数不会调用任何元表的方法,此函数将返回table
--------------------------------------------------------------------------------
select (index, ···)
功能:当index为数字将返回所有index大于index的参数:如:select(2,"a","b") 返回 "b"
当index为"#",则返回参数的总个数(不包括index)
--------------------------------------------------------------------------------
setfenv (f, table)
功能:设置函数f的环境表为table
参数:f可以为函数或调用栈的级别,级别1[默认]为当前的函数,级别0将设置当前线程的环境表
--------------------------------------------------------------------------------
setmetatable (table, metatable)
功能:为指定的table设置元表metatable,如果metatable为nil则取消table的元表,当metatable有__metatable字段时,将触发错误
注:只能为LUA_TTABLE 表类型指定元表
--------------------------------------------------------------------------------
tonumber (e [, base])
功能:尝试将参数e转换为数字,当不能转换时返回nil
base(2~36)指出参数e当前使用的进制,默认为10进制,如tonumber(11,2)=3
--------------------------------------------------------------------------------
tostirng(e)
功能:将参数e转换为字符串,此函数将会触发元表的__tostring事件
--------------------------------------------------------------------------------
type(v)
功能:返回参数的类型名("nil","number", "string", "boolean", "table", "function", "thread", "userdata")
--------------------------------------------------------------------------------
unpack (list [, i [, j]])
功能:返回指定表的索引的值,i为起始索引,j为结束索引
注:本函数只能用于以数字索引访问的表,否则只会返回nil 如:t={"1","cash"}
--------------------------------------------------------------------------------
_VERSION
功能:返回当前Lua的版本号"Lua 5.1".
--------------------------------------------------------------------------------
xpcall (f, err)
功能:与pcall类似,在保护模式下调用函数(即发生的错误将不会反射给调用者)
但可指定一个新的错误处理函数句柄
当调用函数成功能返回true,失败时将返回false加err返回的结果
相关推荐
通过`luaL_newstate()`函数可以创建一个新的Lua环境,并通过`luaL_openlibs()`打开标准库,这样就可以在C++中使用Lua的基本功能了。 2. **加载和执行Lua脚本** 使用`luaL_dofile()`或`luaL_dostring()`函数加载并...
然后,通过`luaL_openlibs`打开标准库,使Lua具备基本功能。 2. **注册C++函数到Lua**:使用`lua_pushcfunction`将C++函数注册到Lua全局表中,使得Lua脚本可以直接调用。C++函数通常需要遵循特定的原型,比如`int ...
### LUA函数库详解 在深入探讨LUA函数库之前,我们先简要了解LUA语言。LUA是一种轻量级的、高效的脚本语言,广泛应用于游戏开发、系统管理、网络编程等多个领域。其强大的函数库是实现各种复杂功能的关键。 #### ...
在Lua编程语言中,unpack函数是一个非常实用且高效的工具,它主要用于从数组类型的table中解包元素。在本文中,我们将详细介绍unpack函数的用法,包括它的基本功能和如何通过实例来掌握它的使用技巧。 首先,让我们...
4. **元编程**:Lua通过Metatables提供了一种灵活的元编程机制,可以改变基本操作的行为,如__add、__mul等元方法。 5. **环境变量与全局环境**:Lua的全局环境是一个特殊的表,所有未在特定环境中定义的变量都存储...
在本文中,我们将深入探讨如何在C++程序中集成Lua,实现C++调用Lua函数以及Lua调用C++函数。 一、C++调用Lua函数 1. 配置环境:首先,你需要在C++项目中包含Lua库。确保已经下载并正确安装了Lua,并将其头文件和库...
总的来说,通过本文的介绍,你应该能够理解如何在C++中使用Lua API调用有参数的Lua函数,并对Lua与C++的交互有了基本的认识。这使得C++程序能灵活地利用Lua脚本实现动态行为,同时也保留了C++的高性能特性。
目前,LuaAction已经实现了对INT(整型)、STRING(字符串)和TABLE(表)三种基本类型的参数支持。在C++中,你可以直接传入这些类型的数据,而在Lua中,它们会被正确地解析和处理。同样,当Lua函数返回这些类型的...
此外,安装LuaJIT(Just-In-Time编译版本的Lua)可以提升性能,使用方法基本与标准Lua相同。 总之,C++调用Lua函数涉及到对Lua C API的理解,包括创建和管理Lua状态机、操作堆栈、读写变量和调用函数等。通过这些...
lua学习 相关函数库和学习参考资料。 包括:lua4.0函数库 lua5.2API函数 lua-table函数库 ...lua基本函数库 lua模式匹配 lua数学库 lua文件处理 lua系统库 lua学习总结 lua元表和元方法 string库函数 简单C访问lua
1. **loadstring函数的基本用法** `loadstring`函数的语法是`loadstring(str[, chunkname])`,其中`str`参数是你要编译的Lua代码字符串,`chunkname`可选,用于设置代码块的名称,通常用于错误报告。当`loadstring...
9. 迭代器:LUA的pairs和ipairs函数用于遍历表,它们是LUA中的迭代器,可以配合next函数实现自定义遍历。 这款"lua练习器"可能包含以下功能: - 代码编辑器:提供文本输入区域,让用户编写LUA脚本。 - 代码运行:...
其中配置包括了cocos2dx 2.0.4和cocos2dx2.1.3在lua中所有函数,类,类的成员变量和方法以及相关枚举定义 使用方法: 1.打开本目录下LuaKeywords.config,将里面内容复制到LuaStudio的自定义函数配置中 2.拷贝cocos...
文档接下来介绍了工程设计的基本流程,包括素材准备、LUA编辑器的使用、API函数的详细说明,以及如何通过教程Demo来说明回调函数的触发使用和编程注意事项。在此过程中,文档详细列举了多个回调函数,并对每个函数的...
通过这两个资源的学习,你不仅可以掌握Lua的基本语法,还能理解其高级特性和应用场景,从而在实际项目中灵活运用。无论是初学者还是有经验的开发者,都能从中获益匪浅。记得实践是检验真理的唯一标准,理论知识结合...
1. Lua语言基础:了解变量、表、函数、控制结构等基本概念。 2. Lua与C/C++的交互:理解如何在C/C++中注册和调用Lua函数,以及如何在Lua中调用C/C++函数。 3. Lua脚本调试:学会使用如luadoc之类的工具来生成和查看...
首先,我们需要了解Delphi和Lua的基本交互机制。在C语言中,通过lua_open函数启动一个Lua虚拟机,然后通过luaL_loadstring或luaL_dostring加载和执行Lua代码。在Delphi中,过程相似,但需使用Delphi的动态链接库...
Lua的内置函数是其核心功能的一部分,提供了许多用于控制流、数据操作和错误处理的基本工具。下面是Lua中的一些主要内置函数的详细介绍: 1. **assert(value)**:这个函数用于检查传入的值是否为`nil`,如果是`nil`...