- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我正在尝试编写一个基本的 C 解析器,但我遇到了很多移位/归约冲突。我尝试了其他问题的许多建议,但似乎没有任何效果。我试图添加一些基于 C 语言的优先级,但我一直在转移/减少冲突。我错过了什么?任何帮助将不胜感激!
Bison :
%union {char* var; char* type}
%token <type> INT DOUBLE BOOL CHAR
%token FOR WHILE
%token IF ELSE PRINTF
%token BYREF BREAK CONTINUE RETURN DELETE FALSE TRUE NEW NULL VOID
%token NUM
%token INCLUDE
%token DOT
%token <var> ID
%nonassoc ELSE
%right '[' ']'
%right '!' '-' '+' '?' ':'
%left AND OR
%right DELETE
%left '&' '*' '/' '%'
%left '<' '>' LE GE EQ NE LT GT
%right MUL_AS DIV_AS ADD_AS MIN_AS MOD_AS INCR DCRS
%error-verbose
%%
expr
: ID
| TRUE
| FALSE
| NULL
|"(" expr ")"
| ID "(" expr_list ")"
| expr "[" expr "]"
| expr '&' expr
| expr '*' expr
| expr '!' expr
| expr INCR
| expr DCRS
| expr '=' expr %prec '='
| expr DIV_AS expr %prec MOD_AS
| expr MOD_AS expr
| expr MUL_AS expr
| expr ADD_AS expr
| expr MIN_AS expr
| expr LE expr
| expr GE expr
| expr NE expr
| expr EQ expr
| expr GT expr
| expr LT expr
| "(" data_type ")" expr
| expr "?" expr ":" expr
| NEW data_type
| NEW data_type "[" expr "]"
| DELETE expr
;
部分报告:(几乎所有的shift/reduce冲突都来 self 的这部分代码)
State 88
49 expr: expr . "[" expr "]"
50 | expr . '&' expr
51 | expr . '*' expr
52 | expr . '!' expr
53 | expr . INCR
54 | expr . DCRS
55 | expr . '=' expr
55 | expr '=' expr . ['!', '&', '*', LE, GE, EQ, NE, LT, GT, MUL_AS, DIV_AS, ADD_AS, MIN_AS, MOD_AS, INCR, DCRS, ";", "[", "]", ")", ')', ';', '=', "?", ":", ',']
56 | expr . DIV_AS expr
57 | expr . MOD_AS expr
58 | expr . MUL_AS expr
59 | expr . ADD_AS expr
60 | expr . MIN_AS expr
61 | expr . LE expr
62 | expr . GE expr
63 | expr . NE expr
64 | expr . EQ expr
65 | expr . GT expr
66 | expr . LT expr
68 | expr . "?" expr ":" expr
'!' shift, and go to state 44
'&' shift, and go to state 45
'*' shift, and go to state 46
LE shift, and go to state 47
GE shift, and go to state 48
EQ shift, and go to state 49
NE shift, and go to state 50
LT shift, and go to state 51
GT shift, and go to state 52
MUL_AS shift, and go to state 53
DIV_AS shift, and go to state 54
ADD_AS shift, and go to state 55
MIN_AS shift, and go to state 56
MOD_AS shift, and go to state 57
INCR shift, and go to state 58
DCRS shift, and go to state 59
"[" shift, and go to state 60
'=' shift, and go to state 61
"?" shift, and go to state 62
'!' [reduce using rule 55 (expr)]
'&' [reduce using rule 55 (expr)]
'*' [reduce using rule 55 (expr)]
LE [reduce using rule 55 (expr)]
GE [reduce using rule 55 (expr)]
EQ [reduce using rule 55 (expr)]
NE [reduce using rule 55 (expr)]
LT [reduce using rule 55 (expr)]
GT [reduce using rule 55 (expr)]
MUL_AS [reduce using rule 55 (expr)]
DIV_AS [reduce using rule 55 (expr)]
ADD_AS [reduce using rule 55 (expr)]
MIN_AS [reduce using rule 55 (expr)]
MOD_AS [reduce using rule 55 (expr)]
INCR [reduce using rule 55 (expr)]
DCRS [reduce using rule 55 (expr)]
"[" [reduce using rule 55 (expr)]
'=' [reduce using rule 55 (expr)]
"?" [reduce using rule 55 (expr)]
$default reduce using rule 55 (expr)
最佳答案
如果您使用优先级声明来消除表达式解析的歧义:
您需要声明每个 运算符。 (在您引用其转换的状态中,错误与 = 相关,您尚未声明其优先级。)
您需要根据语法以正确的顺序列出优先关系。 (例如,&
几乎没有 *
绑定(bind)得那么紧密。)另外,+
和 -
被保留联想。
或者,您可以使用 C 标准中 C 语法中的表达式语法作为基础。它以明确的优先级编写——即不需要优先级声明。无论哪种情况,都值得花时间了解语法的工作原理,既可以作为语言的描述,也可以驱动解析。优先级声明的工作原理是强制解析器明确地将某些歧义解析为移位或归约,因此它们在实践中与不使用优先级的无歧义语法非常相似。
关于c - 解析 - 导致移位/归约冲突的运算符,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46267343/
Or 运算符 对两个表达式进行逻辑“或”运算。 result = expression1 Or expression2 参数 result 任意数值变量。 expression1 任意
Not 运算符 对表达式执行逻辑非运算。 result = Not expression 参数 result 任意数值变量。 expression 任意表达式。 说明 下表显示如何
Is 运算符 比较两个对象引用变量。 result = object1 Is object2 参数 result 任意数值变量。 object1 任意对象名。 object2 任意
\ 运算符 两个数相除并返回以整数形式表示的结果。 result = number1\number2 参数 result 任意数值变量。 number1 任意数值表达式。 numbe
And 运算符 对两个表达式进行逻辑“与”运算。 result = expression1 And expression2 参数 result 任意数值变量。 expression1
运算符(+) 计算两个数之和。 result = expression1 + expression2 参数 result 任意数值变量。 expression1 任意表达式。 exp
我对此感到困惑snippet : var n1 = 5-"4"; var n2 = 5+"4"; alert(n1); alert(n2); 我知道 n1 是 1。那是因为减号运算符会将字符串“4”转
我想我会得到 12,而不是 7。 w++,那么w就是4,也就是100,而w++, w 将是 8,1000;所以 w++|z++ 将是 100|1000 = 1100 将是 12。 我怎么了? int
Xor 运算符 对两个表达式进行逻辑“异或”运算。 result = expression1 Xor expression2 参数 result 任意数值变量。 expression1
Mod 运算符 两个数值相除并返回其余数。 result = number1 Mod number2 参数 result 任意数值变量。 number1 任意数值表达式。 numbe
Imp 运算符 对两个表达式进行逻辑蕴涵运算。 result = expression1 Imp expression2 参数 result 任意数值变量。 expression1 任
Eqv 运算符 执行两个表达式的逻辑等价运算。 result = expression1 Eqv expression2 参数 result 任意数值变量。 expression1 任
我有一个运算符重载的简单数学 vector 类。我想为我的运算符(operator)获取一些计时结果。我可以通过计时以下代码轻松计时我的 +=、-=、*= 和/=: Vector sum; for(s
我是用户定义比较运算符的新手。我正在读一本书,其中提到了以下示例: struct P { int x, y; bool operator、运算符<等),我们
在 SQL 的维基百科页面上,有一些关于 SQL 中 bool 逻辑的真值表。 [1] 维基百科页面似乎来源于 SQL:2003 标准。 等号运算符 (=) 的真值表与 SQL:2003 草案中的 I
我遇到了一个奇怪的 C++ 运算符。 http://www.terralib.org/html/v410/classoracle_1_1occi_1_1_number.html#a0f2780081f
我正在阅读关于 SO 和 answers 中的一个问题,它被提到为: If no unambiguous matching deallocation function can be found, pr
我偶然发现了这个解决方案,但我无法理解其中到底发生了什么。谁能解释一下! 据我了解,它试图通过计算一半的单元格然后将其加倍来计算 a*b 网格中的单元格数量。但是我无法理解递归调用。 请不要建议其他解
Go的基本类型 布尔类型bool 长度:1字节 取值:布尔类型的取值只能是true或者false,不能用数字来表示 整型 通用整型 int / uint(有符号 / 无符号,下面也类似) 长度:根据运
在本教程中,您将学习JavaScript中可用的不同运算符,以及在示例的帮助下如何使用它们。 什么是运算符? 在JavaScript中,运算符是一种特殊符号,用于对运算数(值和变量)执行操作。例如,
我是一名优秀的程序员,十分优秀!