语法和语义错误

语法和语义错误
编程可以是困难的,有很多方法可以犯错误。错误一般分为两类:语法错误和语义错误(逻辑错误)。

语法错误发生时,你写了一个声明针对C++语言的语法无效。这包括错误如缺少分号,未声明的变量,不匹配的括号或大括号,和未结束的字符串。例如,下面的程序包含了相当多的语法错误:

1
2
3
4
5
6
7
#include <iostream>; // preprocessor statements can't have a semicolon on the end
 
int main()
{
    std:cout < "Hi there; << x; // invalid operator (:), unterminated string (missing "), and undeclared variable
    return 0 // missing semicolon at end of statement

幸运的是,编译器通常会捕获语法错误,并生成警告或错误,所以您可以轻松地识别和解决这个问题。然后,这只是一个重新编译的问题,直到你摆脱所有的错误。
一旦你的程序被正确编译,让它实际上产生你想要的结果是很棘手的。语义错误发生时,语句在语法上是有效的,但不做程序员想要的。
有时,这些会导致你的程序崩溃,如在一个除以零的情况下:

2
3
4
5
6
7
8
9
#include <iostream>
 
int main()
{
    int a = 10;
    int b = 0;
    std::cout << a << " / " << b << " = " << a / b; // division by 0 is undefined
    return 0;
}


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
PDF文件大小为130M,PDF带目录索引,高清版 这是Power BI 官方中文教程的高清无删减版 连接到 Oracle数据库 在 Power b| Desktop中运行 Python脚本 在 Power查询编辑器中使用 Python 将外部 Python|DE与 Power bl一起使用 使用 Python创建 Power b|视觉村象 在 Power b| Desktop中运行R脚本 在查询编辑器中使用R 将外部R|DE与 Power b|一起使用 受支持的R包 值接在 Power b| Desktop中输入数据 在 Power Bl Desktop中连接到Exce Power b| Desktop中的 Analysis Services多维数据 通过 Power b| Desktop连接到CS∨文件 在 Power b| Desktop中连接到 Google BigQuery数据库 在 Power BI Desktop中连接到 Impala数据库 通过 Power BI Desktop连接到 OData数据源 在 Power b| Desktop中连接到 Amazon redshift数据库 通过 Power BI Desktop连接到网页 连接到 Power BI Desktop中的雪型计算仓库 连接到 Microsoft Azure Consumption Insights 在 Power Bl Desktop中使用 SAP HANA Power BI Desktop中的 Analysis Services表格数据 在 Power b| Desktop中使用 DirectQuery Oracle和 Teradata数据库的 DirectQuery DirectQuery FA SAP Business Warehouse(BW) DirectQuery和 SAP HANA Power BI Desktop中的假设引用完整性设置 在 Power b| Desktop中使用 SAP BW连接器(预览) 在 Power b| Desktop中使用 One Drive for business链接 第三方服务:适用于 Power b| Desktop的 Facebook连接器 第三方服务:适用于 Power b| Desktop的 Google Analytics连接器 Project Online:通过 Power BI Desktop连接到数据
好的,我了解了您的要求。这是一个比较大的任务,需要一些时间来设计和实现。以下是我建议的步骤和思路: 1. 设计文法:首先,我们需要设计一个符合语言规范的文法,用于描述程序的语法结构和语义规则。这个文法需要满足一些基本的要求,比如不产生二义性、易于实现和维护、符合实际语言使用习惯等。 2. 实现词法分析器:我们需要实现一个词法分析器,用于将程序源代码分解成各个符号(token),并进行基本的错误检查和处理。这个词法分析器需要能够处理常见的错误,比如拼写错误、注释不完整、字符串不完整等。 3. 实现语法分析器:接下来,我们需要实现一个语法分析器,用于检查程序语法结构是否符合文法规则,并进行相应的错误处理。这个语法分析器需要能够处理常见的错误,比如语句不完整、缺少符号、语法错误等。 4. 实现语义分析器:除了语法结构外,我们还需要检查程序的语义规则是否符合要求。这个语义分析器需要能够处理常见的错误,比如类型不匹配、未定义变量、重复定义等。 5. 实现错误处理程序:最后,我们需要实现一个错误处理程序,用于将错误信息局部化处理,并输出相应的错误提示。这个错误处理程序可以采用各种方法,比如错误标记、错误定位、错误提示等。 以上是一个比较基础的框架,可以根据具体需求进行扩展和优化。在实现过程中,我们可以采用各种工具和技术,比如 Lex/Yacc、ANTLR、LLVM、AST、符号表等,来简化开发和提高效率。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值