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

2024-04-15 01:44

本文主要是介绍26、Lua 学习笔记之四(Lua中的基本函数库),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Lua中的基本函数库

    • assert(v[,mess age])
    • collectgarbage (opt [, arg])
    • dofile (filename)
    • error (message [, level])
    • _G全局环境表(全局变量)
    • getfenv(f)
    • getmetatable(object)
    • ipairs (t)
    • load (func [, chunkname])
    • loadfile ([filename])
    • loadstring (string [, chunkname])
    • next (table [, index])
    • pcall (f, arg1, ···)
    • print (···)
    • rawequal (v1, v2)
    • rawget (table, index)
    • rawset (table, index, value)
    • select (index, ···)
      • setfenv (f, table)
    • setmetatable (table, metatable)
    • tonumber (e [, base])
    • tostirng(e)
    • type(v)
    • unpack (list [, i [, j]])
    • _VERSION
    • xpcall (f, err)

assert(v[,mess age])

相当于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相类似)

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返回的结果

这篇关于26、Lua 学习笔记之四(Lua中的基本函数库)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/904585

相关文章

MySql基本查询之表的增删查改+聚合函数案例详解

《MySql基本查询之表的增删查改+聚合函数案例详解》本文详解SQL的CURD操作INSERT用于数据插入(单行/多行及冲突处理),SELECT实现数据检索(列选择、条件过滤、排序分页),UPDATE... 目录一、Create1.1 单行数据 + 全列插入1.2 多行数据 + 指定列插入1.3 插入否则更

C#连接SQL server数据库命令的基本步骤

《C#连接SQLserver数据库命令的基本步骤》文章讲解了连接SQLServer数据库的步骤,包括引入命名空间、构建连接字符串、使用SqlConnection和SqlCommand执行SQL操作,... 目录建议配合使用:如何下载和安装SQL server数据库-CSDN博客1. 引入必要的命名空间2.

Java中的数组与集合基本用法详解

《Java中的数组与集合基本用法详解》本文介绍了Java数组和集合框架的基础知识,数组部分涵盖了一维、二维及多维数组的声明、初始化、访问与遍历方法,以及Arrays类的常用操作,对Java数组与集合相... 目录一、Java数组基础1.1 数组结构概述1.2 一维数组1.2.1 声明与初始化1.2.2 访问

Go语言数据库编程GORM 的基本使用详解

《Go语言数据库编程GORM的基本使用详解》GORM是Go语言流行的ORM框架,封装database/sql,支持自动迁移、关联、事务等,提供CRUD、条件查询、钩子函数、日志等功能,简化数据库操作... 目录一、安装与初始化1. 安装 GORM 及数据库驱动2. 建立数据库连接二、定义模型结构体三、自动迁

ModelMapper基本使用和常见场景示例详解

《ModelMapper基本使用和常见场景示例详解》ModelMapper是Java对象映射库,支持自动映射、自定义规则、集合转换及高级配置(如匹配策略、转换器),可集成SpringBoot,减少样板... 目录1. 添加依赖2. 基本用法示例:简单对象映射3. 自定义映射规则4. 集合映射5. 高级配置匹

SQL BETWEEN 语句的基本用法详解

《SQLBETWEEN语句的基本用法详解》SQLBETWEEN语句是一个用于在SQL查询中指定查询条件的重要工具,它允许用户指定一个范围,用于筛选符合特定条件的记录,本文将详细介绍BETWEEN语... 目录概述BETWEEN 语句的基本用法BETWEEN 语句的示例示例 1:查询年龄在 20 到 30 岁

mysql中insert into的基本用法和一些示例

《mysql中insertinto的基本用法和一些示例》INSERTINTO用于向MySQL表插入新行,支持单行/多行及部分列插入,下面给大家介绍mysql中insertinto的基本用法和一些示例... 目录基本语法插入单行数据插入多行数据插入部分列的数据插入默认值注意事项在mysql中,INSERT I

苹果macOS 26 Tahoe主题功能大升级:可定制图标/高亮文本/文件夹颜色

《苹果macOS26Tahoe主题功能大升级:可定制图标/高亮文本/文件夹颜色》在整体系统设计方面,macOS26采用了全新的玻璃质感视觉风格,应用于Dock栏、应用图标以及桌面小部件等多个界面... 科技媒体 MACRumors 昨日(6 月 13 日)发布博文,报道称在 macOS 26 Tahoe 中

mapstruct中的@Mapper注解的基本用法

《mapstruct中的@Mapper注解的基本用法》在MapStruct中,@Mapper注解是核心注解之一,用于标记一个接口或抽象类为MapStruct的映射器(Mapper),本文给大家介绍ma... 目录1. 基本用法2. 常用属性3. 高级用法4. 注意事项5. 总结6. 编译异常处理在MapSt

MyBatis ResultMap 的基本用法示例详解

《MyBatisResultMap的基本用法示例详解》在MyBatis中,resultMap用于定义数据库查询结果到Java对象属性的映射关系,本文给大家介绍MyBatisResultMap的基本... 目录MyBATis 中的 resultMap1. resultMap 的基本语法2. 简单的 resul