2

今天早些时候,我终于掌握了完整的语法,但遇到了“字符串太长”的 Java 问题。

我知道这个问题已经解决了,但我害怕遇到其他限制,所以我决定改用 C# 目标。我是一名经验丰富的 C++ 程序员,并且学习了 Java 以便能够使用 Antlr4,切换到 C# 没什么大不了的,只是要学习一种新语法。

我现在收到消息:1>CSC : fatal error CS1647: An expression is too long or complex to compile

没有提供其他信息。有没有人用 Antlr4 生成的代码见过这个?我在网上搜索了这条消息,但没有发现任何有用的信息(许多引用了应该修复的旧错误)。

我的项目目前由一个 .cs 文件和 2 个 .g4 文件(词法分析器和解析器语法)组成。

语法非常复杂(实现 IEEE 标准中定义的语言)。

我最初使用 Java 目标实现了语法的一个子集,没有任何问题。

任何指针表示赞赏。

这里有一些额外的信息。我正在使用 Visual Studio 2012。它似乎与我最初看到的 Java 问题的不同版本相同。

我能够创建一个仅包含以下行的示例 C# 文件:

public static readonly string _serializedATN =
    "\x5\x3\x176\x234A\x4\x2\t\x2\x4\x3\t\x3\x4\x4\t\x4\x4\x5\t\x5\x4\x6\t"+
    "\x6\x4\a\t\a\x4\b\t\b\x4\t\t\t\x4\n\t\n\x4\v\t\v\x4\f\t\f\x4\r\t\r\x4"+
    "\xE\t\xE\x4\xF\t\xF\x4\x10\t\x10\x4\x11\t\x11\x4\x12\t\x12\x4\x13\t\x13"+
    "\x4\x14\t\x14\x4\x15\t\x15\x4\x16\t\x16\x4\x17\t\x17\x4\x18\t\x18\x4\x19"+
    "\t\x19\x4\x1A\t\x1A\x4\x1B\t\x1B\x4\x1C\t\x1C\x4\x1D\t\x1D\x4\x1E\t\x1E"+
    "\x4\x1F\t\x1F\x4 \t \x4!\t!\x4\"\t\"\x4#\t#\x4$\t$\x4%\t%\x4&\t&\x4\'"+
    "\t\'\x4(\t(\x4)\t)\x4*\t*\x4+\t+\x4,\t,\x4-\t-\x4.\t.\x4/\t/\x4\x30\t"+
    "\x30\x4\x31\t\x31\x4\x32\t\x32\x4\x33\t\x33\x4\x34\t\x34\x4\x35\t\x35"+
                 ...
                 ...
                 "\x2316\x231E\x2324\x2328\x232D";

这个问题是可重现的。这条线有 4400 多条线长。C# 编译器似乎无法处理这么多的 concat。我试图避免从我的语言中删除关键字并用它们创建一个哈希表。这可能是我目前唯一的解决方案。

4

1 回答 1

0

我环顾四周,发现这可能是由于编译器引发了“深度递归问题”。这意味着编译器由于太复杂而无法解析表达式。有关更多信息,请参阅构建错误:“表达式太长或无法编译”http://ayende.com/blog/3528/setting-out-to-break-the-compiler

于 2013-05-28T08:21:17.297 回答