- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
最近我不得不给出 C 中的词法和语义错误的示例。我提供了以下示例。
我以为下面是词法错误,
int a#;
对于语义错误,我给出了以下示例,
int a[10];
a=100;
但现在我有点困惑是否两者实际上都是语法错误。请给我一些关于这些错误的想法?
最佳答案
首先,错误的分类(如词汇、句法、语义、语用)在细节上有些随意。
如果您将词法错误定义为 lexer 检测到的错误,则格式错误的数字可能是 1,例如 12q4z5
。或带有禁止字符的名称,如 $
您可以将语法错误定义为在 parsing 处检测到的错误时间。但是 C 不是严格意义上的 context-free language , 它的解析器保留上下文信息(例如在符号表中)。
由于所有a
#
和;
都是有效的词位,所以你的a#;
不是词法错误。
其实#
主要在预处理时有用,解析的其实是预处理后的形式,而不是用户给的源码!
许多语义错误与 undefined behavior 的概念有关,比如缺少整数参数的 printf("%d")
。或者越界访问,在你的情况下 printf("%d\n", a[1234]);
一些(但不是全部)语义或语用错误可以通过 static analysis tools 找到.您甚至可以说现代编译器(启用所有警告时)会做一些事情。a=100;
的示例是 typing错误(可以任意称为语法,因为 C 编译器在解析时发现它,也可以称为语义,因为与不是上下文无关属性的类型相关)。而且你有更专业的静态分析工具,比如 Frama-C并且您可以扩展或自定义 GCC 编译器(例如使用 MELT ,一种领域特定语言)以添加您的编译器(例如在 TALPO 中)。
实用错误可能是声明一个巨大的局部变量,例如 here .也许,当 1TB 的 RAM 内存变得普遍时,堆栈将有许多千兆字节,因此该示例可以运行,但不是今天。
关于c - C 中的词法和语义错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15570553/
我试图了解传递给 setTimeout 的箭头函数如何记住上一个执行上下文中的 this 的值。我知道在执行箭头函数时会使用词法作用域规则查找 this 值。这是否意味着箭头函数关闭变量和 this
这个问题已经有答案了: How does the "this" keyword in Javascript act within an object literal? [duplicate] (4 个
我已阅读 this问题,我想我已经理解了投票最多的答案,但他说 since basically every programming language in wide use today uses le
如何让这段宏发挥预期的作用? -- 我想从词法环境中捕获 p 而不必将其作为参数发送给宏。 (define-syntax-rule (fi a b) (if p a b)) ;--->capt
Program A() { x, y, z: integer; procedure B() { y: integer; y=0;
我正在用 Java 实现自己的链表。节点类只有一个名为“name”的字符串字段和一个名为“link”的节点。现在我有一个测试驱动程序类,它只按顺序插入几个名字。现在,我正在尝试编写一种排序方法来按字母
考虑到这个question SO,其中调用了整个 C# 内存中编译器。只有lexical and syntactic analyzing时是必需的:将文本解析为词素流,检查它们并退出。 在System
我有 2 个场景。 这失败了: class F { public X X { get; set; } } 错误 CS0102:类型“F” ' 已经包含 ' X 的定义| ' 这个有效: class
我有一个用 NodeJS 执行的 .js 文件。这是我的文件的内容: var ctry = "America"; function outer(msg) { console.log(msg +
我对编写汇编程序的概念非常陌生,即使在阅读了大量 Material 之后,我仍然很难理解几个概念。 将源文件实际分解为 token 的过程是什么?我相信这个过程称为词法分析,我已经到处搜索有意义的真实
在 static scoping,标识符可以通过分析/解析源代码来确定(与动态作用域不同,动态作用域或多或少需要了解调用者环境)。 我的问题是这样的,因为静态作用域只需要解析源代码以了解作用域和标识符
编辑:我在第一个答案后更改了示例代码,因为我想出了一个简单的版本来回避相同的问题。 我目前正在学习 Common Lisp 的作用域属性。在我认为我有一个坚实的理解之后,我决定编写一些我可以预测结果的
考虑这段代码: class Bar(object): pass class Foo(object): def bar(self): return Bar() f = Foo() def Bar
将 ES6 箭头函数与词法 this 绑定(bind)结合使用非常棒。 但是,我刚才在使用典型的 jQuery 单击绑定(bind)时遇到了一个问题: class Game { foo() {
将 ES6 箭头函数与词法 this 绑定(bind)结合使用非常好。 但是,我刚才在将它与典型的 jQuery 点击绑定(bind)一起使用时遇到了一个问题: class Game { foo(
我是一名优秀的程序员,十分优秀!