openresty开发系列16--lua中的控制结构if-else/repeat/for/while
openresty开发系列16--lua中的控制结构if-else/repeat/for/while一)条件 - 控制结构 if-else if-else 是我们熟知的一种控制结构。Lua 跟其他语言一样,提供了 if-else 的控制结构。1)单个 if 分支 型if 条件 then--body end 条件为真 ,执行if中的body ----------------------- x = 10 if x > 0 thenprint("分支一") end ---- x = 10 if (x > 0) thenprint("分支一") end运行输出:分支一2)两个分支 if-else 型if 条件 then--条件为真 执行此body else--条件为假 执行此body end ---------- x = 10 if x > 0 thenprint("分支一") elseprint("分支二") end 运行输出:分支一3)多个分支 if-elseif-else 型if 条件一 then--条件为真 执行此body elseif 条件二 then..... elseif 条件三 then..... else--条件为假 执行此body endscore = 90 if score == 100 thenprint("分支一") elseif score >= 60 thenprint("分支二") --此处可以添加多个elseif elseprint("分支三") end 运行输出:分支二与 C 语言的不同之处是 else 与 if 是连在一起的,若将 else 与 if 写成 "else if" 则相当于在 else 里嵌套另一个 if 语句,如下代码: score = 0 if score == 100 thenprint("分支一") elseif score >= 60 thenprint("分支二") elseif score > 0 thenprint("分支三")elseprint("分支四")end --与上一示例代码不同的是,此处要添加一个end end 运行输出:分支四二)循环 - while 型控制结构 Lua 跟其他常见语言一样,提供了 while 控制结构,语法上也没有什么特别的。但是没有提供 do-while 型的控制结构,但是提供了功能相当的 repeat。 while 型控制结构语法如下,当表达式值为假(即 false 或 nil)时结束循环。也可以使用 break 语言提前跳出循环。while 条件表达式 do --body end示例代码,求 1 + 2 + 3 + 4 + 5 的结果x = 1 sum = 0while x <= 5 dosum = sum + xx = x + 1 end print(sum) -->output 15continue继续执行,lua是没有这个概念break 终端循环,lua是有的值得一提的是,Lua 并没有像许多其他语言那样提供类似 continue 这样的控制语句用来立即进入下一个循环迭代(如果有的话)。因此,我们需要仔细地安排循环体里的分支,以避免这样的需求。 没有提供 continue,却也提供了另外一个标准控制语句 break,可以跳出当前循环。例如我们遍历 table,查找值为 11 的数组下标索引:local t = {1, 3, 5, 8, 11, 18, 21}local i = 1while i < #t doif 11 == t[i] thenprint("index[" .. i .. "] have right value[11]")breakendi = i + 1; end三)循环 - repeat 控制结构repeat ---重复执行--body until 条件 条件为真时就结束1)until的条件表达式 为真 就结束2)repeat until 控制结构 ,他至少会执行一遍Lua 中的 repeat 控制结构类似于其他语言(如:C++ 语言)中的 do-while,但是控制方式是刚好相反的。简单点说,执行 repeat 循环体后,直到 until 的条件为真时才结束,而其他语言(如:C++ 语言)的 do-while 则是当条件为假时就结束循环。 以下代码将会形成死循环: x = 10 repeatprint(x) until false 该代码将导致死循环,因为until的条件一直为假,循环不会结束 除此之外,repeat 与其他语言的 do-while 基本是一样的。同样,Lua 中的 repeat 也可以在使用 break 退出。四)for 控制结构for 语句有两种形式:数字 for 和范型 for。1)数字型 for 的语法如下: for var = begin, finish, step do--body end 关于数字 for 需要关注以下几点: 1.var 从 begin 变化到 finish,每次变化都以 step 作为步长递增 var 2.begin、finish、step 三个表达式只会在循环开始时执行一次 3.第三个表达式 step 是可选的,默认为 1 4.控制变量 var 的作用域仅在 for 循环内,需要在外面控制,则需将值赋给一个新的变量 5.循环过程中不要改变控制变量的值,那样会带来不可预知的影响for i = 1, 5 doprint(i) end-- output: 1 2 3 4 5for i = 1, 10, 2 doprint(i) end-- output: 1 3 5 7 9for i = 10, 1, -1 doprint(i) end-- output: 10 9 8 7 6 5 4 3 2 1如果不想给循环设置上限的话,可以使用常量 math.huge: for i = 1, math.huge doif (0.3*i^3 - 20*i^2 - 500 >=0) thenprint(i)breakend end2)for 泛型 对lua的table类型进行遍历泛型 for 循环通过一个迭代器(iterator)函数来遍历所有值: -- 打印数组a的所有值 local a = {"a", "b", "c", "d"} for i, v in ipairs(a) doprint("index:", i, " value:", v) end-- output: index: 1 value: a index: 2 value: b index: 3 value: c index: 4 value: d Lua 的基础库提供了 ipairs,这是一个用于遍历数组的迭代器函数。在每次循环中,i 会被赋予一个索引值,同时 v 被赋予一个对应于该索引的数组元素值。下面是另一个类似的示例,演示了如何遍历一个 table 中所有的 key -- 打印table t中所有的key for k in pairs(t) doprint(k) endpairs是可以把数组类型和哈希类型索引值,都会迭代出来对于泛型 for 的使用,再来看一个更具体的示例。假设有这样一个 table,它的内容是一周中每天的名称: local days = {"Sunday", "Monday", "Tuesday", "Wednesday","Thursday", "Friday", "Saturday" }k v ===》 v ,k现在要将一个名称转换成它在一周中的位置。为此,需要根据给定的名称来搜索这个 table。然而 在 Lua 中,通常更有效的方法是创建一个"逆向 table"。例如这个逆向 table 叫 revDays,它以 一周中每天的名称作为索引,位置数字作为值:local revDays = {["Sunday"] = 1,["Monday"] = 2,["Tuesday"] = 3,["Wednesday"] = 4,["Thursday"] = 5,["Friday"] = 6,["Saturday"] = 7}接下来,要找出一个名称所对应的需要,只需用名字来索引这个 reverse table 即可: local x = "Tuesday" print(revDays[x]) -->3当然,不必手动声明这个逆向 table,而是通过原来的 table 自动地构造出这个逆向 table:local days = {"Monday", "Tuesday", "Wednesday", "Thursday","Friday", "Saturday","Sunday" }local revDays = {} for k, v in pairs(days) dorevDays[v] = k end-- print value for k,v in pairs(revDays) doprint("k:", k, " v:", v) end-- output: k: Tuesday v: 2 k: Monday v: 1 k: Sunday v: 7 k: Thursday v: 4 k: Friday v: 5 k: Wednesday v: 3 k: Saturday v: 6 这个循环会为每个元素进行赋值,其中变量 k 为 key(1、2、...),变量 v 为 value("Sunday"、"Monday"、...)。 值得一提的是,在 LuaJIT 2.1 中,ipairs() 内建函数是可以被 JIT 编译的,而 pairs() 则只能被解释执行。因此在性能敏感的场景,应当合理安排数据结构,避免对哈希表进行遍历。事实上,即使未来 pairs 可以被 JIT 编译,哈希表的遍历本身也不会有数组遍历那么高效,毕竟哈希表就不是为遍历而设计的数据结构。五)break,return 关键字1)break 语句 break 用来终止 while、repeat 和 for 三种循环的执行,并跳出当前循环体, 继续执行当前循环之后的语句。下面举一个 while 循环中的 break 的例子来说明: -- 计算最小的x,使从1到x的所有数相加和大于100 sum = 0 i = 1 while true dosum = sum + iif sum > 100 thenbreakendi = i + 1 end print("The result is " .. i) -->output:The result is 14 在实际应用中,break 经常用于嵌套循环中。2)returnreturn 主要用于从函数中返回结果,或者用于简单的结束一个函数的执行。 return 只能写在语句块的最后,一旦执行了 return语句,该语句之后的所有语句都不会再执行。执行return方法,如果实在主函数体里面,不在语句块中;执行return 且没有返回值,之后的语句照样会执行若要写在函数中间,则只能写在一个显式的语句块内,参见示例代码:local function add(x, y)return x + y endlocal function is_positive(x)if x > 0 thenreturn x .. " is > 0"elsereturn x .. " is not > 0"endprint("function end!") end--由于return只出现在前面显式的语句块,所以此语句不注释也不会报错 --,但是不会被执行,此处不会产生输出sum = add(10, 20) print("The sum is " .. sum) -->output:The sum is 30 answer = is_positive(-10) print(answer) -->output:-10 is is not > 0有时候,为了调试方便,我们可以想在某个函数的中间提前 return,以进行控制流的短路。此时我们可以将 return 放在一个 do ... end 代码块中,例如:local function add(x, y)print(1)returnprint(2) end --return 不放在语句块中,return 也没有返回值,不注释该语句,不会报错; 但会执行return之后的业务local function add(x, y)print(1)do return endprint(2) end
转载于:https://www.cnblogs.com/reblue520/p/11429776.html
openresty开发系列16--lua中的控制结构if-else/repeat/for/while相关推荐
- openresty开发系列40--nginx+lua实现获取客户端ip所在的国家信息
openresty开发系列40--nginx+lua实现获取客户端ip所在的国家信息 为了实现业务系统针对不同地区IP访问,展示包含不同地区信息的业务交互界面.很多情况下系统需要根据用户访问的IP信息 ...
- openresty开发系列39--nginx+lua实现接口签名安全认证
一)需求背景 现在app客户端请求后台服务是非常常用的请求方式,在我们写开放api接口时如何保证数据的安全, 我们先看看有哪些安全性的问题 请求来源(身份)是否合法? 请求参数被篡改? 请求的唯一性( ...
- openresty开发系列24--openresty中lua的引入及使用
openresty开发系列24--openresty中lua的引入及使用 openresty 引入 lua 一)openresty中nginx引入lua方式 1)xxx_by_lua ---> ...
- openresty开发系列38--通过Lua+Redis 实现动态封禁IP
openresty开发系列38--通过Lua+Redis 实现动态封禁IP 一)需求背景为了封禁某些爬虫或者恶意用户对服务器的请求,我们需要建立一个动态的 IP 黑名单.对于黑名单之内的 IP ,拒绝 ...
- openresty开发系列29--openresty中发起http请求
openresty开发系列29--openresty中发起http请求 有些场景是需要nginx在进行请求转发 用户浏览器请求url访问到nginx服务器,但此请求业务需要再次请求其他业务: 如用户请 ...
- openresty开发系列28--openresty中操作mysql
openresty开发系列28--openresty中操作mysql Mysql客户端 应用中最常使用的就是数据库了,尤其mysql数据库,那openresty lua如何操作mysql呢? ...
- openresty开发系列27--openresty中封装redis操作
openresty开发系列27--openresty中封装redis操作 在关于web+lua+openresty开发中,项目中会大量操作redis, 重复创建连接-->数据操作-->关闭 ...
- openresty开发系列25--openresty中使用json模块
openresty开发系列25--openresty中使用json模块 web开发过程中,经常用的数据结构为json,openresty中封装了json模块,我们看如何使用 一)如何引入cjson模块 ...
- openresty开发系列26--openresty中使用redis模块
openresty开发系列26--openresty中使用redis模块 在一些高并发的场景中,我们常常会用到缓存技术,现在我们常用的分布式缓存redis是最知名的, 操作redis,我们需要引入re ...
最新文章
- PAT甲级(Advanced Level)真题--1046 Sharing
- 《软件定义网络:基于OpenFlow的SDN》一一2.5 本章总结
- rosetta软件_苹果 Mac 换用 ARM,但不用担心跑 X86 软件会卡
- ASP.NET 3.5 新特性开发向导实践(附项目源码下载)
- 希捷服务器硬盘savvio,2.5英寸进军万转!希捷Savvio硬盘评测
- linux ubuntu QT 下载和安装(Qt Creator)
- linux命令:vmstat
- Minio分布式集群示例:8个节点,每节点1块盘
- 小甲鱼 OllyDbg 教程系列 (五) : 破解 PC Surgeon 之 查找字符串
- OpenSSH 服务器的 20 个最佳实践
- 降采样_嫦娥五号,欢迎回家!我国首次地外天体采样返回任务圆满完成
- 苹果mac三维动画设计渲染软件:Cinema 4D R20 (c4d r20)
- js操作多选框checkBox
- vscode通过ssh远程连接服务器
- mysql 木马_通过mysql写入一句话木马
- TypeError Class constructor ExampleService cannot be invoked withou ‘new‘ at
- 汇编条件判断 eq neq
- java swing paint_Java Paint未在Swing中绘制
- 使用命令能够查看本地计算机,网络故障常用诊断命令及使用方法
- 谷歌相机第一个版本_您的第一个Google地图
热门文章
- 龙芯2h芯片不能进入pmon_国产处理器龙芯地址空间详解
- (仿头条APP项目)4.父类BaseFragment创建,用retrofit和gson获取并解析服务器端数据
- LeetCode 38外观数列39组合总和
- Trie树进阶:Double-Array Trie原理及状态转移过程详解
- html简介及常用标签
- 笔记 - Ali Cloud网络(VPC, SLB) 简介
- String直接赋字符串和new String的区别
- 遍历同辈节电的方法_jQuery遍历
- java list数据的更新,java – ObservableList不更新ArrayList
- 猜猜乐游戏php源码,C/C++百行代码实现热门游戏消消乐功能的示例代码