Lua使用的语法类型是什么?
2021-8-4 16:40:18
收藏:0
阅读:113
评论:1
最近我遇到了LR、LL等概念。Lua属于哪个类别?在这方面有没有或者可以有与官方代码不同的实现方式?
点赞
评论区的留言会收到邮件通知哦~
推荐文章
- 如何在roblox studio中1:1导入真实世界的地形?
- 求解,lua_resume的第二次调用继续执行协程问题。
- 【上海普陀区】内向猫网络招募【Skynet游戏框架Lua后端程序员】
- SF爱好求教:如何用lua实现游戏内调用数据库函数实现账号密码注册?
- Lua实现网站后台开发
- LUA错误显式返回,社区常见的规约是怎么样的
- lua5.3下载库失败
- 请问如何实现文本框内容和某个网页搜索框内容连接,并把网页输出来的结果反馈到另外一个文本框上
- lua lanes多线程使用
- 一个kv数据库
- openresty 有没有比较轻量的 docker 镜像
- 想问一下,有大佬用过luacurl吗
- 在Lua执行过程中使用Load函数出现问题
- 为什么 neovim 里没有显示一些特殊字符?
- Lua比较两个表的值(不考虑键的顺序)
- 有个lua简单的项目,外包,有意者加微信 liuheng600456详谈,最好在成都
- 如何在 Visual Studio 2022 中运行 Lua 代码?
- addEventListener 返回 nil Lua
- Lua中获取用户配置主目录的跨平台方法
- 如何编写 Lua 模式将字符串(嵌套数组)转换为真正的数组?
LR、LL 等算法试图为给定的语法找到解析器。对于每个语法而言,这并不是总能成功的,可以根据实现的可能性进行分类。但您必须知道“语言”和“语法”之间的区别。
可能可以为给定的“语法”创建 LR(k) 解析器,对于某个特定的 k 值而言是这样的。如果是这样,这个“语法”就是 LR(k)。“注意,LR(k) 语法也是 LR(k +1) 语法,而 LL(k) 语法也是 LR(k) 语法。因此,这些不是指每个语法都属于且仅属于一个类别。
任何“语言”都可以通过很多不同的“语法”来进行识别(实际上,是无限的)。这些语法可以是任意复杂的。您总是可以编写一个给定语言的“语法”,即使不是上下文无关语法。如果存在一个给定语言的“语法”是“< _X_ >” ,则我们说这种“语言”是“< _X_ >”。但是,特定语言的特定语法不是“< _X_ >”时,这并不意味着什么。
有一个有趣的定理证明,如果存在任何语言的 LR(k) 语法,则有可能为该语言推导出 LR(1) 语法。因此,虽然 k 参数用于描述语法,但语言只能是 LR(0) 或 LR(1)。“LL(k) 语言”不符合这一点。
Lua 作为语言基本上是 LR(1) 和 LL(2)。其语法是参考手册的一部分,但发表的语法未指定运算符优先级或一些与换行有关的规则。实际解析器是手写的递归下降解析器(至少在我上次检查时是这样),有一些少许偏差,以处理运算符优先级和与LL(1)略有不同的细微偏差。但是,也存在适用于Lua的LALR(1)解析器。