热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Lua语言基础知识,入门必看

文章更新于:2020-05-13注:Lua参考手册:https:amnot.lanzous.comickqlwbContent一、下载安装

文章更新于:2020-05-13
注:Lua 参考手册:https://amnot.lanzous.com/ickqlwb


Content

    • 一、下载安装配置环境
      • 1.1、下载
      • 1.2、安装
    • 二、语法&概念
      • 2.1、关键字
      • 2.2、流程控制
      • 2.3、数据类型
      • 2.4、字符串
        • 表示方法
        • 字符串函数
      • 2.5、数组
      • 2.6、Lua 迭代器
      • 2.7、table(表)
      • 2.8、模块与包
      • 2.9、元表(Metatable)
      • 2.10、协同程序(coroutine)
      • 2.11、文件 I/o
      • 2.12、错误处理
      • 2.13、调试(debug)
      • 2.14、垃圾回收
      • 2.15、面向对象
      • 2.16、数据库访问
    • 三、Enjoy!


一、下载安装配置环境


1.1、下载


  1. 可以去官网:http://www.lua.org/download.html 下载
  2. 也可以使用文首提供的链接

1.2、安装

Windows 安装将下载的文件解压之后,路径配置环境变量即可使用。


二、语法&概念


2.1、关键字



and

break

do

else

elseif

end

false

for

function

if

in

local

nil

not

or

repeat

return

then

true

until

while

2.2、流程控制



判断

if

a = 3
if a == 3 thenprint("a = 3")
end
# a = 3


判断

if else

a = 3
if a == 3 thenprint("a = 3")
elseprint("a != 3")
# a = 3


判断

if else if

a = 4
if a == 3 thenprint("a = 3")
else if a == 4 thenprint("a = 4")
elseprint("a != 3 and a != 4")
# a = 4


循环

while

sum = 0
i = 1
while(i <&#61; 100) dosum &#61; sum &#43; ii &#61; i &#43; 1
end
print(sum)
# 5050


循环

for

sum &#61; 0
for i &#61; 1, 100 dosum &#61; sum &#43; i
end
print(sum)
# 5050


循环

repeat

sum &#61; 0
i &#61; 1
repeatsum &#61; sum &#43; ii &#61; i &#43; 1
until(i > 100)
print(sum)
# 5050


循环

break

while(true) doprint("true")break
end
# true

2.3、数据类型



nil

boolean

number

string

function

userdata

thread

table

数据类型描述
nil无效值&#xff0c;相当于 Null
boolean布尔值&#xff0c;只有 truefalse 两种
number双精度类型的实浮点数
string字符串类型&#xff0c;需要双引号或单引号括起来
function函数类型
userdata表示任意存储在变量中的 C 数据结构
thread用于执行协同程序独立线路
table表&#xff08;table&#xff09;&#xff0c;唯一的数据结构。可以借此创造出各种类型&#xff0c;比如数组和字典

2.4、字符串


表示方法


  1. 使用单引号括起来&#xff1a;hello,world
  2. 使用双引号括起来&#xff1a;"hello,world"
  3. 使用双中括号括起来&#xff1a;[[hello,world]]

字符串函数


函数描述
string.upper(argument)全部转换为大写
string.lower(argument)全部转换为小写
string.gsub(mainString, findString, replaceString, num)替换字符串
string.strfind(str, substr,[init,[end]])查找字符串
string.reverse(argument)翻转字符串
string.format(...)格式化输出字符串
string.char(argument)ascii 数字转换为字符
string.byte(argument, [,int])ascii 字符转换为数字
string.len(argument)计算字符串长度
string.rep(string, n)重复 n 次字符串
..连接两个字符串

2.5、数组

数组&#xff0c;就是相同数据类型的元素按一定顺序排列的集合&#xff0c;可以是一维数组和多维数组。

声明一个一维数组&#xff1a;

array &#61; {"Lua", "Tutorial"}

lua 数组索引默认从 1 开始&#xff0c;
不过你可以指定从 0 开始&#xff0c;也可以从负数开始。

声明一个二维数组&#xff1a;

-- 初始化数组
array &#61; {}
for i&#61;1,3 doarray[i] &#61; {}for j&#61;1,3 doarray[i][j] &#61; i*jend
end-- 访问数组
for i&#61;1,3 dofor j&#61;1,3 doprint(array[i][j])end
end

使用行列数计算索引键防止出现 nil

-- 初始化数组
array &#61; {}
maxRows &#61; 3
maxColumns &#61; 3
for row&#61;1,maxRows dofor col&#61;1,maxColumns doarray[row*maxColumns &#43;col] &#61; row*colend
end-- 访问数组
for row&#61;1,maxRows dofor col&#61;1,maxColumns doprint(array[row*maxColumns &#43;col])print(&#39;index is: &#39;,row*maxColumns &#43;col)end
end

2.6、Lua 迭代器

在Lua中迭代器是一种支持指针类型的结构&#xff0c;它可以遍历集合的每一个元素。
泛型 for 在自己内部保存迭代函数&#xff0c;实际上它保存三个值&#xff1a;迭代函数、状态常量、控制变量。

演示示例&#xff1a;

array &#61; {"Lua", "Tutorial"}for key,value in ipairs(array)
doprint(key, value)
end
# 1 Lua
# 2 Tutorial

2.7、table&#xff08;表&#xff09;


2.8、模块与包


2.9、元表&#xff08;Metatable&#xff09;


2.10、协同程序&#xff08;coroutine&#xff09;


2.11、文件 I/o


2.12、错误处理


2.13、调试&#xff08;debug&#xff09;


2.14、垃圾回收


2.15、面向对象


2.16、数据库访问

支持的数据库有&#xff1a;ODBC, ADO, Oracle, MySQL, SQLite 和 PostgreSQL。


三、Enjoy&#xff01;


推荐阅读
  • Ihavebeenworkingwithbufferingafileonmylocaldrivetoparseandobtaincertaindata.Forte ... [详细]
  • C语言的经典程序有哪些
    本篇内容介绍了“C语言的经典程序有哪些”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何 ... [详细]
  • 基于layUI的图片上传前预览功能的2种实现方式
    本文介绍了基于layUI的图片上传前预览功能的两种实现方式:一种是使用blob+FileReader,另一种是使用layUI自带的参数。通过选择文件后点击文件名,在页面中间弹窗内预览图片。其中,layUI自带的参数实现了图片预览功能。该功能依赖于layUI的上传模块,并使用了blob和FileReader来读取本地文件并获取图像的base64编码。点击文件名时会执行See()函数。摘要长度为169字。 ... [详细]
  • HDU 2372 El Dorado(DP)的最长上升子序列长度求解方法
    本文介绍了解决HDU 2372 El Dorado问题的一种动态规划方法,通过循环k的方式求解最长上升子序列的长度。具体实现过程包括初始化dp数组、读取数列、计算最长上升子序列长度等步骤。 ... [详细]
  • 本文讨论了如何优化解决hdu 1003 java题目的动态规划方法,通过分析加法规则和最大和的性质,提出了一种优化的思路。具体方法是,当从1加到n为负时,即sum(1,n)sum(n,s),可以继续加法计算。同时,还考虑了两种特殊情况:都是负数的情况和有0的情况。最后,通过使用Scanner类来获取输入数据。 ... [详细]
  • 本文介绍了PE文件结构中的导出表的解析方法,包括获取区段头表、遍历查找所在的区段等步骤。通过该方法可以准确地解析PE文件中的导出表信息。 ... [详细]
  • C++字符字符串处理及字符集编码方案
    本文介绍了C++中字符字符串处理的问题,并详细解释了字符集编码方案,包括UNICODE、Windows apps采用的UTF-16编码、ASCII、SBCS和DBCS编码方案。同时说明了ANSI C标准和Windows中的字符/字符串数据类型实现。文章还提到了在编译时需要定义UNICODE宏以支持unicode编码,否则将使用windows code page编译。最后,给出了相关的头文件和数据类型定义。 ... [详细]
  • 第四章高阶函数(参数传递、高阶函数、lambda表达式)(python进阶)的讲解和应用
    本文主要讲解了第四章高阶函数(参数传递、高阶函数、lambda表达式)的相关知识,包括函数参数传递机制和赋值机制、引用传递的概念和应用、默认参数的定义和使用等内容。同时介绍了高阶函数和lambda表达式的概念,并给出了一些实例代码进行演示。对于想要进一步提升python编程能力的读者来说,本文将是一个不错的学习资料。 ... [详细]
  • 本文讨论了一个数列求和问题,该数列按照一定规律生成。通过观察数列的规律,我们可以得出求解该问题的算法。具体算法为计算前n项i*f[i]的和,其中f[i]表示数列中有i个数字。根据参考的思路,我们可以将算法的时间复杂度控制在O(n),即计算到5e5即可满足1e9的要求。 ... [详细]
  • 目录浏览漏洞与目录遍历漏洞的危害及修复方法
    本文讨论了目录浏览漏洞与目录遍历漏洞的危害,包括网站结构暴露、隐秘文件访问等。同时介绍了检测方法,如使用漏洞扫描器和搜索关键词。最后提供了针对常见中间件的修复方式,包括关闭目录浏览功能。对于保护网站安全具有一定的参考价值。 ... [详细]
  • 常用工具(一)
    1.时间戳在线转换工具(1)链接https:tool.lutimestamp(2)说明可以通过此工具:将时间戳转为具体时间点,也可以将具体时间点转为时间戳(3)效果2.JSON在线 ... [详细]
  • Windows下配置PHP5.6的方法及注意事项
    本文介绍了在Windows系统下配置PHP5.6的步骤及注意事项,包括下载PHP5.6、解压并配置IIS、添加模块映射、测试等。同时提供了一些常见问题的解决方法,如下载缺失的msvcr110.dll文件等。通过本文的指导,读者可以轻松地在Windows系统下配置PHP5.6,并解决一些常见的配置问题。 ... [详细]
  • Voicewo在线语音识别转换jQuery插件的特点和示例
    本文介绍了一款名为Voicewo的在线语音识别转换jQuery插件,该插件具有快速、架构、风格、扩展和兼容等特点,适合在互联网应用中使用。同时还提供了一个快速示例供开发人员参考。 ... [详细]
  • MATLAB函数重名问题解决方法及数据导入导出操作详解
    本文介绍了解决MATLAB函数重名的方法,并详细讲解了数据导入和导出的操作。包括使用菜单导入数据、在工作区直接新建变量、粘贴数据到.m文件或.txt文件并用load命令调用、使用save命令导出数据等方法。同时还介绍了使用dlmread函数调用数据的方法。通过本文的内容,读者可以更好地处理MATLAB中的函数重名问题,并掌握数据导入导出的各种操作。 ... [详细]
  • 查找给定字符串的所有不同回文子字符串原文:https://www ... [详细]
author-avatar
邪冫主_70139
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有