- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
根据 "Recursive descent parser" on Wikipedia ,没有回溯的递归下降(又名预测解析)只适用于 LL(k) 文法。
在其他地方,我读到 Lua 的实现使用了这样的解析器。但是,语言不是 LL(k)。实际上,Lua 本质上是模棱两可的: a = f(g)(h)[i] = 1
是指 a = f(g); (h)[i] = 1
还是 a = f; (g)(h)[i] = 1
?这种歧义是通过解析器中的贪婪来解决的(因此上面的内容被解析为错误的 a = f(g)(h)[i]; = 1
)。
这个例子似乎表明预测解析器可以处理不是 LL(k) 的语法。事实上,他们真的可以处理 LL(k) 的超集吗?如果是这样,有没有办法找出给定的语法是否在这个超集中?
换句话说,如果我正在设计一种我想使用预测解析器来解析的语言,我是否需要将该语言限制为 LL(k)?或者我可以申请更宽松的限制吗?
最佳答案
TL; 博士
对于递归下降解析器的合适定义,只有 LL(k) 语言 可以通过递归下降进行解析是绝对正确的。
Lua 可以用递归下降解析器解析,正是因为 语言 是 LL(k);也就是说,Lua 存在一个 LL(k) 文法。 [注1]
1. LL(k) 语言可能有非 LL(k) 文法。
如果存在识别该语言的 LL(k) 语法,则该语言是 LL(k)。这并不意味着每个识别语言的语法都是 LL(k);可能有任意数量的非 LL(k) 语法可以识别该语言。因此,某些语法不是 LL(k) 的事实绝对不能说明语言本身。
2. 许多实用的编程语言都是用歧义的语法来描述的。
在形式语言理论中,只有当语言的每个语法都是二义性时,语言才是 inherently ambiguous。可以肯定地说,没有实用的编程语言本质上是模棱两可的,因为实用的编程语言是确定性解析的(以某种方式)。 [笔记2]。
因为编写严格无歧义的语法可能很乏味,所以语言文档提供歧义语法以及指示如何解决歧义的文本 Material 是很常见的。
例如,许多语言(包括 Lua)都使用不明确包含运算符优先级的语法来记录,从而允许表达式的简单规则:
exp ::= exp Binop exp | Unop exp | term
if-statement ::= "if" '(' exp ')' stmt
| "if" '(' exp ')' stmt "else" stmt
matched-statement ::= matched-if-stmt | other-statement
statement ::= matched-if-stmt | unmatched-if-stmt
matched-if-stmt ::= "if" '(' exp ')' matched-statement "else" matched-statement
unmatched-if-stmt ::= "if" '(' exp ')' statement
| "if" '(' exp ')' matched-statement "else" unmatched-if-stmt
{anbmcmdn|n,m≥0} ∪ {anbncmdm|n,m≥0}
。
program ::= statement-list
statement-list ::= Ø
| statement-list statement
statement ::= assignment | function-call | block | ';'
block ::= "do" statement-list "end"
assignment ::= var '=' exp
exp ::= prefixexp [Note 3]
prefixexp ::= var | '(' exp ')' | function-call
var ::= Name | prefixexp '[' exp ']'
function-call ::= prefixexp '(' exp ')'
Ø
来表示空字符串,而不是
ε
、
λ
或
%empty
。)
exp
的 LL(1) 版本很简单,但结果消除了
var
(可以分配给)和
function-call
(不能)之间的区别:
exp ::= term exp-postfix
exp-postfix ::= Ø
| '[' exp ']' exp-postfix
| '(' exp ')' exp-postfix
term ::= Name | '(' exp ')'
a-or-fc-statement ::= term a-postfix
a-postfix ::= '=' exp
| ac-postfix
c-postfix ::= Ø
| ac-postfix
ac-postfix ::= '(' exp ')' c-postfix
| '[' exp ']' a-postfix
S1 S2
的出现,其中
S1
以
exp
和
S2
结尾,我们需要区分不同类型的 ',关于语句是否以
(
开头,以及独立地,语句是否以
exp
结尾。(实际上只有三种类型,因为没有以 0x2518122313 do43141 和 an1331313313131331331331341 开头的语句. [注4])
statement-list ::= Ø
| s1 statement-list
| s2 s2-postfix
| s3 s2-postfix
s2-postfix ::= Ø
| s1 statement-list
| s2 s2-postfix
s1 ::= block | ';'
s2 ::= Name a-postfix
s3 ::= '(' exp ')' a-postfix
(
的可能的前瞻序列表来决定该非终结符使用哪个替代产生式,然后简单地一个符号“执行”产生式:终结符导致下一个输入符号匹配则丢弃,不匹配则报错;非终端符号导致非终端过程被调用。
exp
映射到终端序列
k
如果
A→ω
。) [注 5]
α
,它只能使用有关符号 α ∈ FIRSTk(ω FOLLOWk(A))
的信息进行确定性解析——无论是变量名还是类型别名——以及正确解析的困难解析涉及模板的 C++ 表达式。 (例如,参见问题 Why can't C++ be parsed with a LR(1) parser? 和 Is C++ context-free or context-sensitive?) (x)*y
扩展的表达式,因此将有四个不同的选项。 关于parsing - 哪些语法可以使用递归下降而不回溯来解析?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45796613/
我发现在使用parse-node包时,不能再使用Parse.Cloud.httpRequest了。我也知道 Parse 的 Image 对象将不可用。 到目前为止,我已经能够用原生的替换一些 Pars
关闭。这个问题是opinion-based 。目前不接受答案。 已关闭 9 年前。 已锁定。这个问题及其答案是locked因为这个问题是题外话,但却具有历史意义。目前不接受新的答案或互动。 我有一个函
开源 Parse Server 是否包含用于配置新 Parse 实例的 Schema API?我试图消除手动创建应用程序的需要。 这是通过 Parse.com 提供的架构 API http://blo
我想从我的云代码发出一个 http 请求,该请求在我的客户端被调用。 最佳答案 一开始我发现这有点令人困惑,所以希望这会有所帮助。 在您的云代码中main.js Parse.Cloud.define(
这部分代码应该读入两个或更多数字(省略主 io 函数),然后是一个“+”来给出总和。使用有理数是因为稍后我将进行乘法和其他此类操作。 data Expression = Number Rationa
我似乎找不到任何关于此的官方信息:Does Parse.Config work on Parse Server?它曾经在 Parse.com 上工作,但是当我尝试迁移到 Parse.Server 时,
我正在尝试找到使用 Parse.com 添加密码要求的最佳程序。似乎最简单的方法是在保存用户数据之前使用云功能执行。我唯一的警告是,只有当密码与数据库中存储的密码不同或者用户不存在于数据库中时,我才想
我是 android 开发、应用程序开发和一般开发的初学者,我正在尝试为我的 android 应用程序设置后端数据库。我决定使用一个名为 back4app 的服务,以便获得更加用户友好的数据库体验,因
我目前正在尝试将 Facebook 登录功能添加到我的应用程序。 根据Android文档,当我添加 compile 'com.parse:parsefacebookutils-v4-android:1
我正在尝试使用 Rebol 2/3 从字符串中解析货币值,货币值的格式为: 10,50 欧元或 10,50 欧元 我在浏览了所有 PARSE 文档后想出了这段代码,我可以在 Red 中找到它,但在 R
代码: DateTimeFormat dateFormat = DateTimeFormat .getFormat("EEE MMM dd HH:mm:ss zzz y
我不再在 Parse 上看到用于导入 JSON 或 CSV 文件的导入按钮。他们是否将其移动到某个地方,或者不再可能导入这些文件类型? 最佳答案 官方原因是这样的: “[导入类按钮] 几天前被删除,因
我正在使用 PHP 从我的服务器检索一些数据。我想在 javascript 应用程序中使用这些数据,所以我正在做这样的事情: var polylines = ; $polylines 只是一个 PHP
我已经开始使用 .NET 4 System.Numerics.BigInteger Structure我遇到了一个问题。 我正在尝试解析一个包含无符号(正数)的十六进制数字的字符串。我得到一个负数。
我正在使用 PHP 从我的服务器检索一些数据。我想在 javascript 应用程序中使用这些数据,所以我正在做这样的事情: var polylines = ; $polylines 只是一个 PHP
在 Go 中,尝试将字符串转换为 time.Time 时,使用时间包的 Parse 方法不会返回预期结果。似乎问题出在时区。我想更改为 ISO 8601 结合 UTC 日期和时间。 package m
我正在尝试将此字符串模式 "4-JAN-12 9:30:14" 解析为 time.Time。 尝试了 time.Parse("2-JAN-06 15:04:05", inputString) 和许多其
从云代码和解析开始。使用this . 如何删除所有 Parse 项目以便开始创建新项目?我收到以下错误: “您想要创建一个新应用程序,还是将 Cloud Code 添加到现有应用程序中?输入“(n)e
我在解析云代码时有这个功能: Parse.Cloud.define("testfunction", function(request, response) { var username = r
最近,我在 parse.com 上做了一些测试。我现在面临在后台作业中使用 Parse.Object.saveAll 的问题。 从 parse.com 的文档来看,后台作业可以运行 15 分钟。我现在
我是一名优秀的程序员,十分优秀!