【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

相关文章

MySQL INSERT语句实现当记录不存在时插入的几种方法

《MySQLINSERT语句实现当记录不存在时插入的几种方法》MySQL的INSERT语句是用于向数据库表中插入新记录的关键命令,下面:本文主要介绍MySQLINSERT语句实现当记录不存在时... 目录使用 INSERT IGNORE使用 ON DUPLICATE KEY UPDATE使用 REPLACE

SpringBoot @Scheduled Cron表达式使用方式

《SpringBoot@ScheduledCron表达式使用方式》:本文主要介绍SpringBoot@ScheduledCron表达式使用方式,具有很好的参考价值,希望对大家有所帮助,如有... 目录Cron 表达式详解1. 表达式格式‌2. 特殊字符解析3. 常用示例‌4. 重点规则5. 动态与复杂场景‌

C++从序列容器中删除元素的四种方法

《C++从序列容器中删除元素的四种方法》删除元素的方法在序列容器和关联容器之间是非常不同的,在序列容器中,vector和string是最常用的,但这里也会介绍deque和list以供全面了解,尽管在一... 目录一、简介二、移除给定位置的元素三、移除与某个值相等的元素3.1、序列容器vector、deque

Spring Boot 集成 Quartz 使用Cron 表达式实现定时任务

《SpringBoot集成Quartz使用Cron表达式实现定时任务》本文介绍了如何在SpringBoot项目中集成Quartz并使用Cron表达式进行任务调度,通过添加Quartz依赖、创... 目录前言1. 添加 Quartz 依赖2. 创建 Quartz 任务3. 配置 Quartz 任务调度4. 启

Spring Boot中定时任务Cron表达式的终极指南最佳实践记录

《SpringBoot中定时任务Cron表达式的终极指南最佳实践记录》本文详细介绍了SpringBoot中定时任务的实现方法,特别是Cron表达式的使用技巧和高级用法,从基础语法到复杂场景,从快速启... 目录一、Cron表达式基础1.1 Cron表达式结构1.2 核心语法规则二、Spring Boot中定

python之流程控制语句match-case详解

《python之流程控制语句match-case详解》:本文主要介绍python之流程控制语句match-case使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录match-case 语法详解与实战一、基础值匹配(类似 switch-case)二、数据结构解构匹

grom设置全局日志实现执行并打印sql语句

《grom设置全局日志实现执行并打印sql语句》本文主要介绍了grom设置全局日志实现执行并打印sql语句,包括设置日志级别、实现自定义Logger接口以及如何使用GORM的默认logger,通过这些... 目录gorm中的自定义日志gorm中日志的其他操作日志级别Debug自定义 Loggergorm中的

在MySQL执行UPDATE语句时遇到的错误1175的解决方案

《在MySQL执行UPDATE语句时遇到的错误1175的解决方案》MySQL安全更新模式(SafeUpdateMode)限制了UPDATE和DELETE操作,要求使用WHERE子句时必须基于主键或索引... mysql 中遇到的 Error Code: 1175 是由于启用了 安全更新模式(Safe Upd

最长公共子序列问题的深度分析与Java实现方式

《最长公共子序列问题的深度分析与Java实现方式》本文详细介绍了最长公共子序列(LCS)问题,包括其概念、暴力解法、动态规划解法,并提供了Java代码实现,暴力解法虽然简单,但在大数据处理中效率较低,... 目录最长公共子序列问题概述问题理解与示例分析暴力解法思路与示例代码动态规划解法DP 表的构建与意义动

关于最长递增子序列问题概述

《关于最长递增子序列问题概述》本文详细介绍了最长递增子序列问题的定义及两种优化解法:贪心+二分查找和动态规划+状态压缩,贪心+二分查找时间复杂度为O(nlogn),通过维护一个有序的“尾巴”数组来高效... 一、最长递增子序列问题概述1. 问题定义给定一个整数序列,例如 nums = [10, 9, 2