CHAR_LITERAL: '\'' (~['\\\r\n] | EscapeSequence) '\'';
fragment EscapeSequence
: '\\' 'u005c'? [btnfr"'\\]
| '\\' 'u005c'? ([0-3]? [0-7])? [0-7]
| '\\' 'u'+ HexDigit HexDigit HexDigit HexDigit
;
在 CHAR_LITERAL 的第一部分,排除掉转义的字符,用来包含正常的不需要转义的字符,我是可以理解的。
但问题是,这里为什么没有排除 \b \t \f " 这些呢?这些不也是需要被转义的吗?\r \n 跟 \b \t \f " 有啥区别吗?
想了一个晚上也没有想明白,然后问了 chat-gpt ,越解释越糊涂
有没有懂的同学,给我一些提示呢
这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。
V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。
V2EX is a community of developers, designers and creative people.