- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我正在用 C# 从头开始编写一个简单的解析器/解释器(没有第三方库)。它编译为字节码,然后我有运行字节码的类。我快要结束了。我刚刚实现了 while
和 for
循环,并且正在研究 if
|else if
|else
block 。
就目前而言,我的解析器要求所有这些结构都使用大括号。我想让它更像 C,并且当 block 只包含一个语句时花括号是可选的。这给我带来了麻烦。
if (condition)
{
// Make curly braces optional when there is just one statement here
}
问题是跟踪状态。解析器如何知道没有花括号的 block 何时结束。一种方法是检查在每条语句之后是否有一个没有生效的大括号 block 。然而,有很多不同的场景可以构成一个声明,因此这些检查需要在很多地方进行。这对我来说有点脆弱。
我只是想知道是否有人这样做过并且知道在没有花括号的情况下跟踪代码块何时结束的巧妙技巧。
最佳答案
你需要调查recursive descent parser .它使创建解析器变得容易得多。假设您的语法如下所示:
statement
: 'if' paren_expr ['{'] statement ['}']
paren_expr
: '(' expr ')'
然后使用递归下降你可以做这样的事情:
public void Statement()
{
if(curToken == Token.If)
{
Eat(Token.If); // Eat is convenience method that moves token pointer on
if(curToken == Token.LParen)
{
Eat(Token.LParen)
ParenExpr();
Eat(Token.RParen);
}
if(curToken == Token.LBrace) // this will signify a block of statements
{
Eat(Token.LBrace);
while(curToken != Token.RBrace)
Statement();
Eat(Token.RBrace);
}
else
Statement();
}
}
public void ParenExpr()
{
// do other token checks
}
对所有非终端执行此操作,您可以轻松构建 AST,并从中生成字节码。
关于c# - 解析没有花括号的代码块的技巧,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56160457/
我用 redis 后端运行 celery。 我想在 centos 6.2 上运行 celery 花作为守护进程。 我知道花是 Tornado 应用程序,所以我应该使用一个进程来运行 Tornado 应
我在一台服务器上有几个项目,它们使用具有不同 BROKER_URL 的 celery 包。Flower 允许一个 BORKER_URL 作为命令选项: celery flower --broker=a
我正在使用芹菜和花卉。当我访问Flower中的“任务”标签时,我可以看到我的任务正在注册,甚至可以在“状态”列中看到“成功”标签以及所有内容。 但是,在“监视器”选项卡上,所有图形(“成功任务”,“失
我正在尝试创建一个有 5 个叶子的 css 花 - 没有任何有希望的尝试。我正在尝试创建什么:有 5 片叶子的 CSS 花,每片叶子可以有三种不同的状态(小、中、大)。我找到了 http://ross
如果我有一个变体,像这样: using my_variant = boost::variant; 有没有一种简单的方法可以将变体可以包含的类型提取到 Boost.Hana 元组中,以便满足以下条件:
调用 Flower API's /api/task/apply/* 只是挂起而没有返回结果,即使任务已根据 Web UI 处理并成功。 重现错误: # hangs even though task s
我有一个模板函数,默认情况下没有定义,但它由某些类型特化: template auto foo(bar &, const T &) -> void; template <> auto foo(bar
就目前情况而言,这个问题不太适合我们的问答形式。我们希望答案得到事实、引用资料或专业知识的支持,但这个问题可能会引发辩论、争论、民意调查或扩展讨论。如果您觉得这个问题可以改进并可能重新开放,visit
我是一名优秀的程序员,十分优秀!