【Cprimerplus_02】】表达式和语句、副作用和序列点

2023-12-05 14:18

本文主要是介绍【Cprimerplus_02】】表达式和语句、副作用和序列点,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

表达式和语句

​ ​ 总结:C语言中的表达式是由运算符和操作对象组成的一个的算式。语句是C语言程序设计中的基本构件块,每条语句都可看作一条完整的计算机指令,其特点是以分号作为语句的结束标志。常见的语句有空语句、表达式语句、循环语句、选择语句、跳转语句等。复合语句也被称为语句块,是指花括号在内的多条语句。特定情况下,一个复合语句可以被当作一条语句来分析和处理。

​ 从功能上看,表达式负责进行一系列的数据计算和求值操作。也就是说,每一个表达式都会有一个最终的值,而语句则是程序设计中指令的基本单位,两者从性质和含义上有着根本性的区别。

1 表达式

表达式(expression):由运算符和运算对象组成。最简单的表达式是一个单独的运算对象,以此为基础可以建立复杂的对象。

子表达式(subexpression):是一个更大的表达式的一部分较小的的表达式。

每一个表达式都有一个值:
  • ==C表达式的一个最重要的特性是,每个表达式都有一个值。==要获得这个值,必须根据运算符优先级的特定顺序来执行操作。
  • 有赋值运算符(=)的表达式的值是什么?这些表达式的值与赋值运算符左侧变量的值相等。因此,表达式 q= 5*2作为一个整体的表达式的值是10。
  • 对于 6 + (c = 3+6)这样的的表达式看上去奇怪,但是在C中完全合法,值为15,但是不建议使用,因为它是两个表达子表达式的和,每个子表达式都有一个值。
2 语句
1.语句(statement)

是C程序的基本构建块。一条语句相当于一条完整的计算机指令,更确切地说,语句可以改变值或者调用函数。

  • 并不是所有的指令都是语句。比如 x = 6 + ( y = 5);该句中的子表达式 y = 5是一条完整的指令,但是它只是语句的一部分。因为一条完整的指令不一定是一条语句,所以分号用于识别在这种情况下的语句(即简单语句)。

  • C把末尾加上一个分号的表达式都看作是一条语句(即表达式语句),因此8; 或者3+4;这样写也没有问题,但是这些语句在程序中什么都不做,没有什么用。

2.讨论一些常见语句,或者容易被误认为是语句的部分

**表达式语句:**C程序设计语言的表达式语句由表达式加上分号“;”组成。

  • 赋值表达式语句:为变量分配一个值
  • 函数表达式语句:会引起函数调用

**迭代语句:**比如while语句,有时也被称为结构化语句,因为它的结构比简单的赋值表达式复杂。

**空语句:**什么都没有,什么都不做的语句。

以上讨论的都是简单语句。

复合语句(compound statement):用花括号括起来的一条或者多条语句。复合语句也称为 “块(block)”

注意,**声明:**声明创建了名称和类型,并为其分配内存位置。注意,声明不是表达式语句,也就是说,删除了声明后面的分号,剩下的部分不是一个表达式,也没有值根据C标准,声明不是语句,这与C++不同。

3 副作用和序列点

副作用(side effect):副作用是对数据对象或者文件的修改。

例如 states = 50;它的副作用是将变量的值设置为50,与之相反的是,这似乎更像是主要目的?

但是从C语言的角度来看,主要目的是对表达式求值。给出表达式 4+6;,C会对其求值为10;给出表达式states = 50;C会对其求值得50,对该表达式的副作用是把变量states的值改为50。

跟赋值运算符一样,递增和递减符也有副作用,使用它们的主要目的就是使用其副作用。类似地,调用printf()函数时,它显示的信息其实是副作用。(printf的返回值是待显示字符的个数)

序列点(sequence point):程序执行的点。在该点上,所有的副作用都在进入下一步之前发生。

在C语言中, 语句中的分号标记了一个序列点。意思是,在一个语句中,赋值运算符、递增运算符和递减运算符对运算对象做的改变必须在下一条语句之前完成。另外,任何一个完整表达式的结束也是一个序列点。

完整表达式(full expression):指这个表达式不是另一个更大表达式的子表达式。例如,表达式语句中的表达式和while循环中的作为测试条件的表达式,都是完整表达式。

序列点有助于分析后缀递增何时发生。

while(guests++ < 10)printf("%d",&guests);

对于上面的代码,可能在初学C语言的时候认为“先使用值,再递增它”的意思是,在printf()语句中先使用guests,再递增它。但是,表达式guests++ < 10是一个完整的表达式,因为它是while循环测试的条件,所以该表达式的结束就是一个序列点。

因此,C保证了在程序转至执行printf()之前发生副作用(即递增guests),同时,使用了后缀形式保证了guests在完成与10的比较后才进行递增。

现在,考虑这条语句:

y = (4 + x++) + (6 + x++);

表达式4 + x++不是一个完整的表达式,所以C无法保证在x在子表达式4 + x++后求值后立即递增x。这里,完整表达式是整个赋值表达式语句,分号标记了序列点。所以,C保证程序在执行下一条语句之前递增x两次。C并未指明是在对子表达式求值以后递增x,还是对所有的表达式求值后再递增x,因此,要尽量避免编写类似的语句。

这篇关于【Cprimerplus_02】】表达式和语句、副作用和序列点的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/457915

相关文章

Python中的sort方法、sorted函数与lambda表达式及用法详解

《Python中的sort方法、sorted函数与lambda表达式及用法详解》文章对比了Python中list.sort()与sorted()函数的区别,指出sort()原地排序返回None,sor... 目录1. sort()方法1.1 sort()方法1.2 基本语法和参数A. reverse参数B.

分析 Java Stream 的 peek使用实践与副作用处理方案

《分析JavaStream的peek使用实践与副作用处理方案》StreamAPI的peek操作是中间操作,用于观察元素但不终止流,其副作用风险包括线程安全、顺序混乱及性能问题,合理使用场景有限... 目录一、peek 操作的本质:有状态的中间操作二、副作用的定义与风险场景1. 并行流下的线程安全问题2. 顺

Python的Darts库实现时间序列预测

《Python的Darts库实现时间序列预测》Darts一个集统计、机器学习与深度学习模型于一体的Python时间序列预测库,本文主要介绍了Python的Darts库实现时间序列预测,感兴趣的可以了解... 目录目录一、什么是 Darts?二、安装与基本配置安装 Darts导入基础模块三、时间序列数据结构与

C# LiteDB处理时间序列数据的高性能解决方案

《C#LiteDB处理时间序列数据的高性能解决方案》LiteDB作为.NET生态下的轻量级嵌入式NoSQL数据库,一直是时间序列处理的优选方案,本文将为大家大家简单介绍一下LiteDB处理时间序列数... 目录为什么选择LiteDB处理时间序列数据第一章:LiteDB时间序列数据模型设计1.1 核心设计原则

MySQL中REPLACE函数与语句举例详解

《MySQL中REPLACE函数与语句举例详解》在MySQL中REPLACE函数是一个用于处理字符串的强大工具,它的主要功能是替换字符串中的某些子字符串,:本文主要介绍MySQL中REPLACE函... 目录一、REPLACE()函数语法:参数说明:功能说明:示例:二、REPLACE INTO语句语法:参数

MySQL ORDER BY 语句常见用法、示例详解

《MySQLORDERBY语句常见用法、示例详解》ORDERBY是结构化查询语言(SQL)中的关键字,隶属于SELECT语句的子句结构,用于对查询结果集按指定列进行排序,本文给大家介绍MySQL... 目录mysql ORDER BY 语句详细说明1.基本语法2.排序方向详解3.多列排序4.常见用法示例5.

Linux中的自定义协议+序列反序列化用法

《Linux中的自定义协议+序列反序列化用法》文章探讨网络程序在应用层的实现,涉及TCP协议的数据传输机制、结构化数据的序列化与反序列化方法,以及通过JSON和自定义协议构建网络计算器的思路,强调分层... 目录一,再次理解协议二,序列化和反序列化三,实现网络计算器3.1 日志文件3.2Socket.hpp

Oracle查询表结构建表语句索引等方式

《Oracle查询表结构建表语句索引等方式》使用USER_TAB_COLUMNS查询表结构可避免系统隐藏字段(如LISTUSER的CLOB与VARCHAR2同名字段),这些字段可能为dbms_lob.... 目录oracle查询表结构建表语句索引1.用“USER_TAB_COLUMNS”查询表结构2.用“a

MySQL 内存使用率常用分析语句

《MySQL内存使用率常用分析语句》用户整理了MySQL内存占用过高的分析方法,涵盖操作系统层确认及数据库层bufferpool、内存模块差值、线程状态、performance_schema性能数据... 目录一、 OS层二、 DB层1. 全局情况2. 内存占js用详情最近连续遇到mysql内存占用过高导致

解密SQL查询语句执行的过程

《解密SQL查询语句执行的过程》文章讲解了SQL语句的执行流程,涵盖解析、优化、执行三个核心阶段,并介绍执行计划查看方法EXPLAIN,同时提出性能优化技巧如合理使用索引、避免SELECT*、JOIN... 目录1. SQL语句的基本结构2. SQL语句的执行过程3. SQL语句的执行计划4. 常见的性能优