C语言——运算符及表达式

C语言——运算符及表达式

  • 运算符
    • 运算符的分类
    • ++(自增运算符)、--(自减运算符)
    • 赋值运算符
    • 逗号运算符(顺序求值运算符)
  • 表达式

运算符

运算符的分类

C语言的运算符范围很宽,除了控制语句和输入输出以外的几乎所有的基本操作都可以作为运算符处理。通过查阅课本可知运算符的分为以下13类:
在这里插入图片描述
我下面主要要讲述的是算术运算符、赋值运算符、以及逗号运算符;

算数运算符
算术运算符总共有+(加法运算符) 、-(减法运算符) 、*(乘法运算符) 、/(出发运算符) 、%(求余运算符) 五种,要想了解算数运算符及运算符的使用必须先要了解运算符的优先级和结合性;
那么什么时候会用到运算符的的优先级呢?
就是在不同优先级的运算符混合在一起使用的时候高优先级的会先结合;
结合性,所谓结合性就是运算符的结合方向,不同的运算符都有着不同的结合方向,当同一优先级的运算符混合时运算符会按照结合性结合。
运算符的优先级和结合性如下表所示:
在这里插入图片描述
算数运算符的用法和数学上了类似,需要注意的是求余运算符(%):
求余运算的规则
1、求余运算中运算数不能是小数,必须是整数;
2、除数不能为零;
3、结果的符号取决于左操作数;
那何为左操作数呢?
左操作数也就是左值,通俗来说就是能够放在表达式左边的变量,左值的定义是可定位的变量也就是可以在内存空间中找到相应的内存空间。
和左值相反的是右值,右值是不可定位的也就是在内存空间中找不到相应的空间;
常见求余运算符的用法:%2用于求偶数和奇数;%N可以取出在0~N - 1范围内的数,等等;
在产生一定范围内的随机数时也可以用到求余运算符,例如:

#include <stdio.h>int main(void)
{int i = 0;srand(time(NULL));for(i = 0; i < 10; ++i){printf("%d\n", rand() % 100);}return 0;
}

rand()产生的其实是伪随机数也就是产生的第一组数据是随机的如果再将程序执行一遍时打印的数字和上次打印的数据是一样的,原因是rand()起初含有一个默认的种子如果不改变种子输出的就是一样的数据,而srand()的作用就是给rand()种下一个种子把time(NULL)(返回值是秒的数值)作为参数传进srand(),这样以变化的时间来作为种子就不断的产生不是每次全部都一样的随机数了。

++(自增运算符)、–(自减运算符)

++自增运算符的常见用法:++i、i++;
i++先用后加前提是i++要参与到别的运算中才会起作用;
i++的值在内存中是这样存储的:
假设i在内存中占四个字节,i本身的值占用上面的四个字节并且会在其下面开辟出一块临时的空间用于存放表达式也就是i++的值;
在这里插入图片描述

++i也就是常说先加后用,这个先加后用的前提是++i要参与到别的运算中才会起作用;
和i++不同的是++i本身的值和表达式的值都是存放在同一块空间内的,所以说++i的效率更高,因为++i不用开辟额外的空间。
–自减运算符和自增运算符同理;

自增运算符问题:

#include <stdio.h>int main()
{int i = 3;printf("%d\n", i+++++i);return 0;
}

问输出结果是什么?
这里程序会报错,原因是C语言编译器在处理时会从左往右逐个扫描,将字符尽可能多的结合成C语言运算符,所以遇到第一个+时没有运算符结合,遇到第二个+和第一个+结合成++,遇到第三个+无法和++结合,遇到第四个+和第三个+结合成++,遇到第五个+无法和++结合自己作为单个运算符所以i+++++i表达使得结合性是这样的最后(((i++)++)+i),因为i++是一个表达式,表达式为右值( )++缺左值所以程序会报错。

#include <stdio.h>int main(void)
{int i = 0;printf("%d %d\n", i, i++);return 0;
}

在实际的应用中是不建议这样使用的,因为在多数系统中的函数传参顺序是从右往左的而且i++先用后加到底什么时候加没有统一的规定。推荐用法如下:

#include <stdio.h>int main()
{int n = i;int m = i++;printf("%d %d\n", n, m);return 0;
}

赋值运算符

赋值运算符常见用法:

int a = 0int a = b = c = d = 0;

当只有赋值运算符时只用考虑结合性,即从右往左。
不同类型间的赋值:
高精度 = 低精度例如float、double赋值给int类型这样会导致精度丢失,反之将低精度赋值给高精度类型比如把int赋值给float、double类型会发生精度提升,所以在进行赋值运算时要看清楚数据类型否则输出结果可能会和预想结果哦不一致。
整型赋值规则:
int => short
long => int
short => char
长类型=>短类型 //高位截断

int a = 0x12345678;
short b = a;
printf("%#x\n", b);

长类型赋值给短类型 ,会发生高位截断,输出结果是0x5678;
短类型=>长类型
无符号短类型 =>长类型 //高位补0

short a = 0x1234;
int b = a;
printf("%#x\n", b);

无符号短类型 赋值给长类型高位补0,输出结果为0x1234;

有符号短类型 =>长类型 //符号位扩展 (高位补符号位)

short a = 0x8234;
int b = a;
printf("%#x\n", b);

符号短类型赋值给长类型符号位会扩展 即高位补符号位,输出结果为0xffff8234。

逗号运算符(顺序求值运算符)

语法:
表达式1,表达式2,…,…,…
逗号表达式整个表达式的值是最后一个表达式的值,比如:

int a = 10;
int b = (1 + 2, a++, 3 + 4);

b的值就是3 + 4这个表达式的结果即7;

表达式

表达式就是由运算符和运算数构成字符序列且表达式都是有值的和数据类型的 。
讲到表达式需要注意的是数据类型的转换特别是隐式类型的转换,
在这里插入图片描述
横向的箭头表示必定的转换字符型(char)和短整型(short)在运算时必须先转换为整型(int),float型数据必须先转换为double型的数据,这样做的目的是提高运算精度。
纵向的箭头表示的是当运算对象为不同数据类型时的转换方向,例如int和double的数据类型进行运算时需要将int转换为double类型。
需要注意的时箭头方向只表示数据类型的高低由低往高转,不是表示int先转换为unsigned int 在转换为long再转换为double。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/50316.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Internet Download Manager2024免费流行的下载加速器

1. Internet Download Manager&#xff08;IDM&#xff09;是一款流行的下载加速器&#xff0c;多线程下载使速度更快。 2. 用户界面友好&#xff0c;易于操作&#xff0c;支持多种浏览器集成和自动捕获下载。 3. 恢复中断的下载&#xff0c;动态文件分割技术提高效率。 4. 定…

Vue3与Element-plus配合 直接修改表格中的一项数据——控制输入框的显示与隐藏

利用控制与隐藏输入框,直接修改表格中的每一项数据。 <!-- 表格模块 --> <div><el-table :data"tablelist" style"width: 100%"><el-table-column align"center" prop"deposit" label"接单押金">&l…

『 Linux 』信号的写入与保存

文章目录 信号的发送信号的保存sigset_t 类型与信号集操作函数阻塞信号集(信号屏蔽字)操作函数未决信号集操作函数验证阻塞信号集与未决信号集 信号的发送 $ kill -l1) SIGHUP 2) SIGINT 3) SIGQUIT 4) SIGILL 5) SIGTRAP6) SIGABRT 7) SIGBUS 8) SIGFPE 9) SIGKILL 10)…

【音视频】RTSP、RTMP与流式传输

文章目录 前言RTSP与RTMPRTSP&#xff08;Real-Time Streaming Protocol&#xff09;RTMP&#xff08;Real-Time Messaging Protocol&#xff09;主要差异 什么是流式传输&#xff1f;流式传输的特点流式传输与传统下载的区别 使用VLC播放RTSP监控 总结 前言 在现代网络环境中…

一天搞定React(3)——Hoots组件【已完结】

Hello&#xff01;大家好&#xff0c;今天带来的是React前端JS库的学习&#xff0c;课程来自黑马的往期课程&#xff0c;具体连接地址我也没有找到&#xff0c;大家可以广搜巡查一下&#xff0c;但是总体来说&#xff0c;这套课程教学质量非常高&#xff0c;每个知识点都有一个…

学习笔记之Java篇(0726)

2、封装 1、封装的使用细节 2、开发中封装的简单规则&#xff1a; 属性一般使用private访问权限。 属性私有后&#xff0c;提供相应的get/set方法来访问相关属性&#xff0c;这些方法通常是public修饰后&#xff0c;以提供属性的赋值与读取操作&#xff08;注意&#xff1a;b…

情绪稳定的人有什么特点?

第一部分&#xff1a;至纯之人&#xff0c;大器晚成 1.1 单纯&#xff0c;不是天真 你知道吗&#xff1f;那些能够成就大事的人&#xff0c;往往在人性上非常单纯。他们对外界的需求很低&#xff0c;更多的是向内寻求。这样的人&#xff0c;他们的内心世界像一片净土&#xff…

二叉树 N0=N2+1

N0 叶子节点&#xff0c;度为 0 的节点&#xff1b; N1 度为 1 的节点&#xff1b; N2 度为 2 的节点 度为 0 的节点为&#xff1a;H、I、J、K、G 度为 1 的节点&#xff1a;E、F 度为 2 的节点&#xff1a;A、B、D、C N0 N2 1&#xff0c;即&#xff1a;度为 0 的叶子节点 …

力扣高频SQL 50 题(基础版)第四题

文章目录 力扣高频SQL 50 题&#xff08;基础版&#xff09;第四题584.寻找用户推荐人题目说明思路分析实现过程准备数据实现方式结果截图 力扣高频SQL 50 题&#xff08;基础版&#xff09;第四题 584.寻找用户推荐人 题目说明 表: Customer -------------------- | Colu…

虚拟机配置RabbitMQ集群教程

RabbitMQ是常用的一款消息中间件&#xff0c;那么如何在我们虚拟机中创建其集群呢&#xff1f;跟着博主这篇文章让你一步到位 本篇搭建的是三台机器为一个集群&#xff01;假设大家虚拟机都为初始化状态&#xff0c;从0开始&#xff08;注意集群搭建需要CentOS8以上环境&#x…

【五】MySql8基于m2芯片arm架构Ubuntu24虚拟机安装

文章目录 1. 更新系统包列表2. 安装 MySQL APT Repository3. 更新系统包列表4. 安装 MySQL Server5. 运行安全安装脚本6. 验证 MySQL 安装7. 配置远程连接7.1 首先要确认 MySQL 配置允许远程连接&#xff1a;7.2 重启 MySQL 服务&#xff1a;7.3 检查 MySQL 用户权限&#xff1…

详解数据结构之二叉树(二叉链,使用递归)

详解数据结构之二叉树(二叉链&#xff0c;使用递归实现) 二叉链 二叉链&#xff0c;二叉树的链式结构&#xff0c;其中数据域data存放节点的值&#xff0c;指针域left和right分别存放左孩子节点的地址、右孩子节点的地址。 typedef int BinaryTDataType; typedef struct Bin…

ChatGPT的原理和成本

ChatGPT就是人机交互的一个底层系统&#xff0c;某种程度上可以类比于操作系统。在这个操作系统上&#xff0c;人与AI之间的交互用的是人的语言&#xff0c;不再是冷冰冰的机器语言&#xff0c;或者高级机器语言&#xff0c;当然&#xff0c;在未来的十来年内&#xff0c;机器语…

K8S 部署peometheus + grafana 监控

安装说明 如果有下载不下来的docker镜像可以私信我免费下载。 系统版本为 Centos7.9 内核版本为 6.3.5-1.el7 K8S版本为 v1.26.14 动态存储&#xff1a;部署文档 GitHub地址 下载yaml 文件 ## 因为我的K8S 版本比较新&#xff0c;我下载的是当前的最新版本&#xff0c;你的要…

go语言day18 reflect反射

Golang-100-Days/Day16-20(Go语言基础进阶)/day19_Go语言反射.md at master rubyhan1314/Golang-100-Days (github.com) 7-19 接口&#xff1a;底层实现_哔哩哔哩_bilibili 一、interface接口 接口类型内部存储了一对pair(value,Type) type interface { type *Type // 类型信…

Linux:传输层(2) -- TCP协议(2)

目录 1. 流量控制 2. 滑动窗口 3. 拥塞控制 4. 延迟应答 5. 捎带应答 6. 面向字节流 7. 粘包问题 8. TCP异常情况 1. 流量控制 接收端处理数据的速度是有限的. 如果发送端发的太快 , 导致接收端的缓冲区被打满 , 这个时候如果发送端继续发送 , 就会造成丢包, 继而引…

7月24日JavaSE学习笔记

序列化版本控制 序列化&#xff1a;将内存对象转换成序列&#xff08;流&#xff09;的过程 反序列化&#xff1a;将对象序列读入程序&#xff0c;转换成对象的方式&#xff1b;反序列化的对象是一个新的对象。 serialVersionUID 是一个类的序列化版本号 private static fin…

dsp c6657 SYS/BIOS学习笔记

1 SYS/BIOS简介 SYS/BIOS是一种用于TI的DSP平台的嵌入式操作系统&#xff08;RTOS&#xff09;。 2 任务 2.1 任务调度 SYS/BIOS任务线程有0-31个优先级&#xff08;默认0-15&#xff0c;优先级0被空闲线程使用&#xff0c;任务最低优先级为1&#xff0c;最高优先级为15&am…

Java | Leetcode Java题解之第264题丑数II

题目&#xff1a; 题解&#xff1a; class Solution {public int nthUglyNumber(int n) {int[] dp new int[n 1];dp[1] 1;int p2 1, p3 1, p5 1;for (int i 2; i < n; i) {int num2 dp[p2] * 2, num3 dp[p3] * 3, num5 dp[p5] * 5;dp[i] Math.min(Math.min(num2…

昇思25天学习打卡营第20天|CV-ResNet50图像分类

打卡 目录 打卡 图像分类 ResNet网络介绍 数据集准备与加载 可视化部分数据集 残差网络构建 Building Block 结构 代码实现 Bottleneck结构 代码实现 构建ResNet50网络 代码定义 模型训练与评估 可视化模型预测 重点&#xff1a;通过网络层数加深&#xff0c;感知…