lua学习笔记之四(Lua中的基本函数库)

最后更新于:2022-04-01 10:07:09

### Lua中的基本函数库 表1 <table border="1" cellspacing="0" cellpadding="0"><tbody><tr><td valign="top" style="background:#99CCFF"><p style="text-align:center">基本函数库</p></td><td valign="top" style="background:#99CCFF"><p style="text-align:center">功能</p></td><td valign="top" style="background:#99CCFF"><p style="text-align:center">参数</p></td><td valign="top" style="background:#99CCFF"><p>备注</p></td></tr><tr><td valign="top"><p><span style="color:rgb(137,197,7)">assert(v[,mess age])                 </span></p></td><td valign="top"><p>相当于C的断言</p></td><td valign="top"><p align="left">v:当表达式v为nil或false将触发错误,</p><p align="left">message:发生错误时返回的信息,默认为"assertion failed!"</p></td><td valign="top"><p> </p></td></tr><tr><td valign="top"><p><span style="color:#89C507">collectgarbage (opt [, arg])</span></p></td><td valign="top"><p>是垃圾收集器的通用接口,用于操作垃圾收集器</p></td><td valign="top"><p align="left">opt:操作方法标志</p><p align="left">"Stop": 停止垃圾收集器 </p><p align="left">"Restart": 重启垃圾收集器 </p><p align="left">"Collect": 执行一次全垃圾收集循环</p><p align="left">"Count": 返回当前Lua中使用的内存量(以KB为单位)</p><p align="left">"Step": 单步执行一个垃圾收集. 步长 "Size" 由参数arg指定 (大型的值需要多步才能完成),如果要准确指定步长,需要多次实验以达最优效果。如果步长完成一次收集循环,将返回True</p><p align="left">"Setpause": 设置 arg/100 的值作为暂定收集的时长 </p><p align="left">"Setstepmul": 设置 arg/100 的值,作为步长的增幅(即新步长=旧步长*arg/100)</p></td><td valign="top"><p> </p></td></tr><tr><td valign="top"><p><span style="color:#89C507">dofile (filename)</span></p></td><td valign="top"><p>打开并且执行一个lua块,当忽略参数filename时,将执行标准输入设备(stdin)的内容。返回所有块的返回值。当发生错误时,dofile将错误反射给调用者</p></td><td valign="top"><p><span style="color:#FB0007">注:</span><span style="color:#FB0007">dofile</span><span style="color:#FB0007">不能在保护模式下运行</span></p></td><td valign="top"><p> </p></td></tr><tr><td valign="top"><p><span style="color:#89C507">error (message [, level])</span></p></td><td valign="top"><p>终止正在执行的函数,并返回message的内容作为错误信息(error函数永远都不会返回)</p></td><td valign="top"><p align="left">通常情况下,error会附加一些错误位置的信息到message头部.</p><p align="left">Level参数指示获得错误的位置,</p><p align="left">Level=1[默认]:为调用error位置(文件+行号)</p><p align="left">Level=2:指出哪个调用error的函数的函数</p><p>Level=0:不添加错误位置信息</p></td><td valign="top"><p> </p></td></tr><tr><td valign="top"><p><span style="color:#89C507">_G</span><span style="color:#89C507">全局环境表</span><span style="color:#89C507">(</span><span style="color:#89C507">全局变量</span><span style="color:#89C507">)</span></p></td><td valign="top"><p>记录全局环境的变量值的表 _G._G = _G</p></td><td valign="top"><p> </p></td><td valign="top"><p> </p></td></tr><tr><td valign="top"><p><span style="color:#89C507">getfenv(f)</span></p></td><td valign="top"><p>返回函数f的当前环境表</p></td><td valign="top"><p>f可以为函数或调用栈的级别,级别1[默认]为当前的函数,级别0或其它值将返回全局环境_G</p></td><td valign="top"><p> </p></td></tr><tr><td valign="top"><p><span style="color:#89C507">getmetatable(object)</span></p></td><td valign="top"><p>返回指定对象的元表(若object的元表.__metatable项有值,则返回object的元表.__metatable的值),当object没有元表时将返回nil</p></td><td valign="top"><p> </p></td><td valign="top"><p> </p></td></tr><tr><td valign="top"><p align="left"><span style="color:#89C507">ipairs (t)</span></p><p> </p></td><td valign="top"><p align="left">返回三个值 迭代函数、表、0</p><p align="left">多用于穷举表的键名和键值对</p><p align="left">如:for i,v in ipairs(t) do   end</p><p align="left">每次循环将索引赋级i,键值赋给v</p></td><td valign="top"><p><span style="color:#FB0007">注:本函数只能用于以数字索引访问的表</span><span style="color:#FB0007">如:</span><span style="color:#FB0007">t={"1","cash"}</span></p></td><td valign="top"><p> </p></td></tr><tr><td valign="top"><p><span style="color:#89C507">load (func [, chunkname])</span></p></td><td valign="top"><p align="left">装载一个块中的函数,每次调用func将返回一个连接前一结的字串,在块结尾处将返回nil</p><p align="left">当没有发生错误时,将返回一个编译完成的块作为函数,否则返回nil加上错误信息,此函数的环境为全局环境</p><p>chunkname用于错误和调试信息</p></td><td valign="top"><p> </p></td><td valign="top"><p> </p></td></tr><tr><td valign="top"><p><span style="color:#89C507">loadfile ([filename])</span></p></td><td valign="top"><p>与load类似,但装载的是文件或当没有指定filename时装载标准输入(stdin)的内容</p></td><td valign="top"><p> </p></td><td valign="top"><p> </p></td></tr><tr><td valign="top"><p><span style="color:#89C507">loadstring (string [, chunkname])</span></p></td><td valign="top"><p align="left">与load类似,但装载的内容是一个字串</p><p>如:assert(loadstring(s))()</p></td><td valign="top"><p> </p></td><td valign="top"><p> </p></td></tr><tr><td valign="top"><p><span style="color:#89C507">next (table [, index])</span></p></td><td valign="top"><p>允许程序遍历表中的每一个字段,返回下一索引和该索引的值。</p></td><td valign="top"><p align="left">table:要遍历的表</p><p align="left">index:要返回的索引的前一索中的号,当index为nil[]时,将返回第一个索引的值,当索引号为最后一个索引或表为空时将返回nil</p><p><span style="color:#FB0007">注:可以用</span><span style="color:#FB0007">next(t)</span><span style="color:#FB0007">来检测表是否为空</span><span style="color:#FB0007">(</span><span style="color:#FB0007">此函数只能用于以数字索引的表与</span><span style="color:#FB0007">ipairs</span><span style="color:#FB0007">相类似</span><span style="color:#FB0007">)</span></p></td><td valign="top"><p> </p></td></tr><tr><td valign="top"><p><span style="color:#89C507">ipairs (t)</span></p></td><td valign="top"><p align="left">返回三个值 next函数、表、0</p><p align="left">多用于穷举表的键名和键值对</p><p>如:for n,v in pairs(t) do end</p></td><td valign="top"><p align="left">每次循环将索引赋级i,键值赋给v</p><p><span style="color:#FB0007">注:本函数只能用于以键名索引访问的表</span><span style="color:#FB0007">如:</span><span style="color:#FB0007">t={id="1",name="cash"}</span></p></td><td valign="top"><p> </p></td></tr><tr><td valign="top"><p><span style="color:#89C507">pcall (f, arg1, ···)</span></p></td><td valign="top"><p align="left">在保护模式下调用函数(即发生的错误将不会反射给调用者)</p><p>当调用函数成功能返回true,失败时将返回false加错误信息</p></td><td valign="top"><p> </p></td><td valign="top"><p> </p></td></tr><tr><td valign="top"><p><span style="color:#89C507">print (···)</span></p></td><td valign="top"><p>简单的以tostring方式格式化输出参数的内容</p></td><td valign="top"><p> </p></td><td valign="top"><p> </p></td></tr><tr><td valign="top"><p><span style="color:#89C507">rawequal (v1, v2)</span></p></td><td valign="top"><p>检测v1是否等于v2,此函数不会调用任何元表的方法</p></td><td valign="top"><p> </p></td><td valign="top"><p> </p></td></tr><tr><td valign="top"><p><span style="color:#89C507">rawget (table, index)</span></p></td><td valign="top"><p align="left">获取表中指定索引的值,此函数不会调用任何元表的方法,成功返回相应的值,当索引不存在时返回nil</p></td><td valign="top"><p><span style="color:#FB0007">注:本函数只能用于以数字索引访问的表</span><span style="color:#FB0007">如:</span><span style="color:#FB0007">t={"1","cash"}</span></p></td><td valign="top"><p> </p></td></tr><tr><td valign="top"><p><span style="color:#89C507">rawset (table, index, value)</span></p></td><td valign="top"><p>设置表中指定索引的值,此函数不会调用任何元表的方法,此函数将返回table</p></td><td valign="top"><p> </p></td><td valign="top"><p> </p></td></tr><tr><td valign="top"><p><span style="color:#89C507">select (index, ···)</span></p></td><td valign="top"><p align="left">当index为数字将返回所有index大于index的参数:如:select(2,"a","b") 返回 "b"</p><p align="left">当index为"#",则返回参数的总个数(不包括index)</p></td><td valign="top"><p> </p></td><td valign="top"><p> </p></td></tr><tr><td valign="top"><p><span style="color:#89C507">setfenv (f, table)</span></p></td><td valign="top"><p>设置函数f的环境表为table</p></td><td valign="top"><p>f可以为函数或调用栈的级别,级别1[默认]为当前的函数,级别0将设置当前线程的环境表</p></td><td valign="top"><p> </p></td></tr><tr><td valign="top"><p><span style="color:#89C507">setmetatable (table, metatable)</span></p></td><td valign="top"><p align="left">指定的table设置元表metatable,如果metatable为nil则取消table的元表,当metatable有__metatable字段时,将触发错误</p></td><td valign="top"><p><span style="color:#FB0007">注:只能为</span><span style="color:#FB0007">LUA_TTABLE</span><span style="color:#FB0007">表类型指定元表</span></p></td><td valign="top"><p> </p></td></tr><tr><td valign="top"><p><span style="color:#89C507">tonumber (e [, base])</span></p></td><td valign="top"><p>尝试将参数e转换为数字,当不能转换时返回nil</p></td><td valign="top"><p>base(2~36)指出参数e当前使用的进制,默认为10进制,如tonumber(11,2)=3</p></td><td valign="top"><p> </p></td></tr><tr><td valign="top"><p><span style="color:#89C507">tostirng(e)</span></p></td><td valign="top"><p align="left">将参数e转换为字符串,此函数将会触发元表的__tostring事件</p></td><td valign="top"><p> </p></td><td valign="top"><p> </p></td></tr><tr><td valign="top"><p><span style="color:#89C507">type(v)</span></p></td><td valign="top"><p>返回参数的类型名("nil","number", "string", "boolean", "table", "function", "thread", "userdata")</p></td><td valign="top"><p> </p></td><td valign="top"><p> </p></td></tr><tr><td valign="top"><p><span style="color:#89C507">unpack (list [, i [, j]])</span></p></td><td valign="top"><p align="left">返回指定表的索引的值,i为起始索引,j为结束索引</p></td><td valign="top"><p><span style="color:#FB0007">注:本函数只能用于以数字索引访问的表</span><span style="color:#FB0007">,</span><span style="color:#FB0007">否则只会返回</span><span style="color:#FB0007">nil</span><span style="color:#FB0007">如:</span><span style="color:#FB0007">t={"1","cash"}</span></p></td><td valign="top"><p> </p></td></tr><tr><td valign="top"><p><span style="color:#89C507">_VERSION</span></p></td><td valign="top"><p>返回当前Lua的版本号"Lua 5.1".</p></td><td valign="top"><p> </p></td><td valign="top"><p> </p></td></tr><tr><td valign="top"><p><span style="color:#89C507">xpcall (f, err)</span></p></td><td valign="top"><p align="left">与pcall类似,在保护模式下调用函数(即发生的错误将不会反射给调用者)</p><p align="left">但可指定一个新的错误处理函数句柄</p><p>当调用函数成功能返回true,失败时将返回false加err返回的结果</p></td><td valign="top"><p> </p></td><td valign="top"><p> </p></td></tr></tbody></table> 引用博客:http://www.cnblogs.com/whiteyun/archive/2009/08/12/1543184.html
';