【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

相关文章

Java Lambda表达式的使用详解

《JavaLambda表达式的使用详解》:本文主要介绍JavaLambda表达式的使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、前言二、Lambda表达式概述1. 什么是Lambda表达式?三、Lambda表达式的语法规则1. 无参数的Lambda表

Mybatis Plus JSqlParser解析sql语句及JSqlParser安装步骤

《MybatisPlusJSqlParser解析sql语句及JSqlParser安装步骤》JSqlParser是一个用于解析SQL语句的Java库,它可以将SQL语句解析为一个Java对象树,允许... 目录【一】jsqlParser 是什么【二】JSqlParser 的安装步骤【三】使用场景【1】sql语

利用Python实现时间序列动量策略

《利用Python实现时间序列动量策略》时间序列动量策略作为量化交易领域中最为持久且被深入研究的策略类型之一,其核心理念相对简明:对于显示上升趋势的资产建立多头头寸,对于呈现下降趋势的资产建立空头头寸... 目录引言传统策略面临的风险管理挑战波动率调整机制:实现风险标准化策略实施的技术细节波动率调整的战略价

sql语句字段截取方法

《sql语句字段截取方法》在MySQL中,使用SUBSTRING函数可以实现字段截取,下面给大家分享sql语句字段截取方法,感兴趣的朋友一起看看吧... 目录sql语句字段截取sql 截取表中指定字段sql语句字段截取1、在mysql中,使用SUBSTRING函数可以实现字段截取。例如,要截取一个字符串字

PostgreSQL 序列(Sequence) 与 Oracle 序列对比差异分析

《PostgreSQL序列(Sequence)与Oracle序列对比差异分析》PostgreSQL和Oracle都提供了序列(Sequence)功能,但在实现细节和使用方式上存在一些重要差异,... 目录PostgreSQL 序列(Sequence) 与 oracle 序列对比一 基本语法对比1.1 创建序

Java中的Lambda表达式及其应用小结

《Java中的Lambda表达式及其应用小结》Java中的Lambda表达式是一项极具创新性的特性,它使得Java代码更加简洁和高效,尤其是在集合操作和并行处理方面,:本文主要介绍Java中的La... 目录前言1. 什么是Lambda表达式?2. Lambda表达式的基本语法例子1:最简单的Lambda表

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

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

C++使用printf语句实现进制转换的示例代码

《C++使用printf语句实现进制转换的示例代码》在C语言中,printf函数可以直接实现部分进制转换功能,通过格式说明符(formatspecifier)快速输出不同进制的数值,下面给大家分享C+... 目录一、printf 原生支持的进制转换1. 十进制、八进制、十六进制转换2. 显示进制前缀3. 指

MySQL 中的 LIMIT 语句及基本用法

《MySQL中的LIMIT语句及基本用法》LIMIT语句用于限制查询返回的行数,常用于分页查询或取部分数据,提高查询效率,:本文主要介绍MySQL中的LIMIT语句,需要的朋友可以参考下... 目录mysql 中的 LIMIT 语句1. LIMIT 语法2. LIMIT 基本用法(1) 获取前 N 行数据(

MySQL中动态生成SQL语句去掉所有字段的空格的操作方法

《MySQL中动态生成SQL语句去掉所有字段的空格的操作方法》在数据库管理过程中,我们常常会遇到需要对表中字段进行清洗和整理的情况,本文将详细介绍如何在MySQL中动态生成SQL语句来去掉所有字段的空... 目录在mysql中动态生成SQL语句去掉所有字段的空格准备工作原理分析动态生成SQL语句在MySQL