『C语言初阶』第六章-操作符详解
前言
今天小羊又来为铁汁们更新C语言初阶的操作符详解,我们在平时写代码时总会写到一些算术操作符和赋值操作符,可是当铁汁们遇到其他的操作符时,就会望而却步,甚至写出一些bug,所以这期我给铁汁们带来新鲜出炉的操作符详解~
操作符分类
算术操作符移位操作符位操作符赋值操作符单目操作符关系操作符逻辑操作符条件操作符逗号表达式下标引用、函数调用和结构成员
算术操作符
算术操作符是最常见的:
| + | - | * | / | % |
|---|
注意:
- 除%操作符之外,其他的算术操作符都可以作用于整数和浮点数
- 使用/操作符时,如果两个操作符都为整数,则执行整数除法,结果为整数。若其中有一个为浮点数,则执行浮点数除法,结果为浮点数。
- %操作符的两个操作数必须为整数
分析示例1
#include<stdio.h>
int main()
{int a = 4, b = 0;int c = a / b;printf("%d", c);return 0;
}

分析:/操作符的除数不能为0,否则编译器会报错,就跟数学中分数中的分母不能0是一个道理。
分析示例2
#include<stdio.h>
int main()
{int a = 8, b = 3;int c = a / b;int d = a % b;printf("c=%d\n", c);printf("d=%d\n", d);return 0;
}

分析:C语言中的/操作符结果只保留整数部分(8/3=2……3),而%操作符是保留余数部分。
移位操作符
| <<(左移操作符) | >>(右移操作符) |
|---|
注:移位操作符的操作数只能是整数
移位操作符的作用是什么呢?这里的“位”是指二进制位,故移位操作符是指移动一个数的二进制位。并且我们得清楚一个概念:整数在内存中存储的是二进制的补码,所以移动的是这个数的补码的二进制位。
二进制的三种形式:
- 原码:二进制展开
- 反码:原码的符号位不变,其他位按位取反(最高位是符号位:正数的符号位为0,负数的符号位为1)
- 补码:反码加1
注:正整数的原码、反码、补码相同
左移操作符
定义:即操作数的二进制位向左移动
移位规则:
左边抛弃、右边补0
图法示例:

总结:左移有翻倍的效果,左移一位的结果是原来的两倍,左移两位是原来的四倍。
注:num左移后,num本身的值并没有改变,因为移位操作符并不具有重新赋值的功能,若是移位之后再赋值给自己,num的值才会发生改变。
右移操作符
定义:即操作数的二进制位向右移动
移位规则:
逻辑移位:
左边用0填充,右边丢弃算术移位:
左边用原该值的符号位填充,右边丢弃
图法示例

总结:右移一位会减少到原来的二分之一,右移两位会减少到原来的四分之一。
注:
- 对于移位运算符,不能移动
负数位,这个是标准未定义的。 - 无论左移还是右移,
移动的位数不要太多,比如总共32位,若是移动33位,无法得知
位操作符
| &(按位与) | 丨(按位或) | ^(按位异或) |
|---|---|---|
| 左右操作数都为真才为真,否则都为假 | 只要一边为真,则为真 | 相同为假,相异为真 |
注:在二进制中1为真,0为假,他们的操作数必须是整数,使用对象为内存中二进制的补码
用法示例
#include <stdio.h>
int main()
{int x = 66, y = 34;int a = x & y;int b = x | y;int c = x ^ y;printf("a=%d\nb=%d\nc=%d", a, b, c);return 0;
}
运行结果:


小试牛刀
不能创建临时变量(第三个变量),实现两个数的交换。
#include <stdio.h>
int main()
{int a = 10;int b = 20;printf("交换前:a = %d b = %d\n", a, b);a = a ^ b;b = a ^ b;a = a ^ b;printf("交换后:a = %d b = %d\n", a, b);return 0;
}
这里采用的思想就是0 ^ a = a、a ^ a = 0
a = a ^ b ,将a带入b = a ^ b中,就得到了b = a ^ b ^ b=a,将b带入a = a^b中,就得到了a=a ^ a ^ b= b,因此就可以将两个数实现交换。
赋值操作符
赋值操作符是最最常用的操作符,它可以让你得到你想得到的任意的值。
int a=10;
double b=9.0;
char c='a';
a =4;
b=9.7;
c='t';
复合赋值符
| a +=b | a -= b | a *= b | a /= b | a %= b | a >>= b | a <<= b | a &= b | a丨= b | a ^ = b |
|---|---|---|---|---|---|---|---|---|---|
| a=a+b | a=a-b | a=a*b | a=a/b | a=a%b | a=a>>b | a=a<<b | a=a&b | a=a丨b | a=a^b |
单目操作符
| ! | - | + | & | sizeof | ~ | - - | ++ | * | (类型) |
|---|---|---|---|---|---|---|---|---|---|
| 逻辑反操作 | 负值 | 正值 | 取地址 | 操作数的类型长度(以字节为单位) | 对一个数的二进制按位取反 | 前置、后置– | 前置、后置++ | 间接访问操作符(解引用操作符) | 强制类型转换 |
| !0=1,!1=0 | 略 | 略 | 取出变量地址 | ↓下文详解 | 对一个数二进制按位取反,~101011=010100 | ↓下文详解 | ↓下文详解 | 见指针章详解 | ↓下文详解 |
(类型)强制类型转换:
int n=10;
float m=2.0f;
m=(float)n;
sizeof和数组
sizrof()是一个操作符,用于计算操作数占空间大小,单位是字节。
可以以类型、指针和函数等作为参数。
分析示例
#include<stdio.h>
void test1(int arr1[])
{printf("\n%d\n", sizeof(arr1));
}
void test2(char arr2[])
{printf("%d\n", sizeof(arr2));
}
void test3(float arr3[])
{printf("%d\n", sizeof(arr3));
}
void test4(double arr4[])
{printf("%d\n", sizeof(arr4));
}
int main()
{int a = 0;float b = 0.0f;double c = 0.00f;long long d = 12345;int arr1[10] = { 0 };char arr2[10] = { 0 };float arr3[10] = { 0 };double arr4[10] = { 0 };//计算变量大小printf("%d\n", sizeof(a));printf("%d\n", sizeof(b));printf("%d\n", sizeof(c));printf("%d\n", sizeof(d));//计算类型大小printf("\n%d\n", sizeof(int));printf("%d\n", sizeof(float));printf("%d\n", sizeof(double));printf("%d\n", sizeof(long long));//计算数组大小printf("\n%d\n", sizeof(arr1));printf("%d\n", sizeof(arr2));printf("%d\n", sizeof(arr3));printf("%d\n", sizeof(arr4));//计算地址大小test1(arr1);test2(arr2);test3(arr3);test4(arr4);return 0;
}

分析:
在数组传参时,传递的是数组的首地址,从而计算的是地址的大小计算地址大小有两种结果:在32位机器上是4字节,在64位机器上是8字节
前置++与后置++
前置++:操作数先自增1,后再被使用(先++再使用)
后置++:操作数先被使用,后再自增1(先使用再++)
#include <stdio.h>
int main()
{int a = 5, c = 0;//前置++c = ++a;//先a自增1使得a的值变为6,然后再被赋值到c.printf("%d\n", c);//6printf("%d\n", a);//6//后置++a = 5, c = 0;c = a++;//先使a被赋值到c,此时a=5,赋值完成后,a再自增1,变为6.printf("%d\n", c);//5printf("%d\n", a);//6return 0;
}
前置- -与后置- -效果相同
关系操作符
| > | >= | < | <= | != | == |
|---|---|---|---|---|---|
| 用于测试”不相等“ | 用于测试“相等 |
关系操作符的返回结果只有真或假
常见错误:
在实际编程中,关系运算符= =不能和=搞混,导致错误
逻辑操作符
| && | 丨丨 |
|---|---|
| 逻辑与 (并且) | 逻辑或(或者) |
用法示例
#include <stdio.h>
int main()
{int i = 0, m = 0, a = 0, b = 2, c = 3, d = 4;i = a++ && ++b && d++;printf("a = %d\nb = %d\nc = %d\nd = %d\n", a, b, c, d);m = a++||++b||d++;printf("\na = %d\nb = %d\nc = %d\nd = %d\n", a, b, c, d);return 0;
}

分析:
&&和||有一个重要的特点:当第一个表达式已经能确定整条语句的结果时,后面剩余的表达式将不会执行。
上例中:
- a++ && ++b && d++,咱们先看a++,先使用a再++,而a为0,0为假,所以无论后面的表达式是真是假,语句的整体结果都为假。所以执行完a++后,++b和d++不再执行。
”假“&&”任意“为”假“ - a++||++b||d++,咱们先看a++,先使用a再++,a=1后自增1,a=2,2为真,所以后面++b和d++也不用再执行。
”真“||”任意“为”真“
条件操作符
| exp1 ? exp2 : exp3 ; |
|---|
执行逻辑:
当表达式1的结果为真,则执行表达式2,否则就执行表达式3
用法示例
当我们比较两个数的大小时,通常会想到使用if语句来解决:
#include <stdio.h>
int main()
{int a = 0, b = 0;scanf("%d%d", &a, &b);if (a > b){printf("Max is %d", a);}else printf("Max is %d", b);return 0;
}
而现在我们可以转换为更为简单的写法:
#include <stdio.h>
int main()
{int a = 0, b = 0,c = 0;scanf("%d%d", &a, &b);c = a > b ? a : b;printf("Max is %d", c);return 0;
}
逗号表达式
| exp1 , exp2 , exp3,… |
|---|
逗号表达式就是用逗号隔开的多个表达式
运算规则:
从左向右依次执行,整个表达式的结果是最后一个表达式的结果。
用法示例
#include <stdio.h>
int main()
{int m = 0, a = 1, b = 2, c = 3, d = 5;m = (a++, b + 2, c *=2, c + d);printf("m=%d\n", m);printf("a=%d,b=%d,c=%d,d=%d", a, b, c, d);return 0;
}

逗号表达式运用的场景不是很多,但是能灵活运用也有很多妙处。
下标引用、函数调用和结构成员
下标引用操作符
使用方法:数组名[操作数]
具体见C语言之数组
函数调用操作符
接受一个或者多个操作数:第一个操作数是函数名,剩余的操作数就是传递给函数的参数。
使用方法:
函数名(参数1,参数2......)
int sum(int x,int y);
void test1(const char* str);
结构体成员访问操作符
.结构体 .成员名
->结构体指针->成员名
#include<stdio.h>
struct Stu
{char name[10];char sex[5];int age;double stature;
};
#include <stdio.h>
int main()
{struct Stu s1 = { "jonny","男","19",1.79 };printf("姓名:%s\n", s1.name);struct Stu* s = &s1;printf("性别:%s\n", s->sex);s->stature = 1.88;printf("身高:%.3lf", s->stature);return 0;
}
好勒,今天小羊这期C语言初阶的操作符详解大致讲解完毕,剩余一小部分会在后面的文章中见~
相关文章:
『C语言初阶』第六章-操作符详解
前言 今天小羊又来为铁汁们更新C语言初阶的操作符详解,我们在平时写代码时总会写到一些算术操作符和赋值操作符,可是当铁汁们遇到其他的操作符时,就会望而却步,甚至写出一些bug,所以这期我给铁汁们带来新鲜出炉的操作…...
企业知识文档管理+群晖nas安全云存储
企业知识管理系统,利用软件系统或其他工具的企业管理方法,利用软件系统或其他工具,对组织中大量的有价值的方案、策划、成果、经验等知识进行分类存储和管理,积累知识资产避免流失,促进知识的学习、共享、培训、再利用…...
《吐血整理》进阶系列教程-拿捏Fiddler抓包教程(9)-Fiddler如何设置捕获Https会话
1.简介 由于近几年来各大网站越来越注重安全性都改成了https协议,不像前十几年前直接是http协议直接裸奔在互联网。还有的小伙伴或者童鞋们按照上一篇宏哥的配置都配置好了,想大展身手抓一下百度的包,结果一试傻眼了,竟然毛都没有…...
对比CahtGPT Bard Claude2对中文的理解
对比CahtGPT Bard Claude2对中文的理解 今天简单测试了一下目前这三个很火的模型对中文的理解能力 简单问题 鲁迅和周树人的关系 Bard CahtGPT Claude 介绍一下平凡的世界这本书 Bard CahtGPT...
安全测试国家标准解读——并发程序安全
本系列文章主要围绕《GB/T 38674—2020 信息安全技术 应用软件安全编程指南》进行讲解,该标准是2020年4月28日,由国家市场监督管理总局、国家标准化管理委员会发布,2020年11月01日开始实施。我们对该标准中一些常见的漏洞进行了梳理ÿ…...
《吐血整理》进阶系列教程-拿捏Fiddler抓包教程(12)-Fiddler设置IOS手机抓包,你知多少???
1.简介 Fiddler不但能截获各种浏览器发出的 HTTP 请求,也可以截获各种智能手机发出的HTTP/ HTTPS 请求。 Fiddler 能捕获Android 和 Windows Phone 等设备发出的 HTTP/HTTPS 请求。同理也可以截获iOS设备发出的请求,比如 iPhone、iPad 和 MacBook 等苹…...
MySQL中锁的简介——行级锁
1.行级锁概念及分类 可通过以下语句查看意向锁和行锁的加锁情况: select object_schema,object_name,index_name,lock_type,lock_mode,lock_data from performance_schema.data_locks;InnoDB的行锁是针对于索引加的锁,不通过索引条件检索数据࿰…...
4 个最常见的自动化测试挑战及应对措施
有人说:“杂乱无章的自动化只会带来更快的混乱。”不仅更快,而且是更严重、更大的混乱。如果使用得当,自动化可以成为测试团队中令人惊叹的生产力助推器和系统的质量增强器。自动化测试的关键是要正确运用,这是初始最困难的部分。…...
23款奔驰GLE450豪华型升级AMG直瀑式中网,战斗感立马提升了一个档次
奔驰GLE450豪华型升级AMG竖杠中网前进气格栅,AMG中网竖杠格栅,镀铬饰条呈圆弧状,色泽均衡,质感顺滑,极富冲击力。AMG专属字标,与中网卡扣装配紧密,凸显AMG的身份象征,点睛之笔又不显…...
ALLEGRO之Logic
本文主要讲述ALLEGRO的Logic菜单。 (1)Net Logic:暂不清楚; (2)Net Schedule:暂不清楚; (3)AssignDifferential Pair:暂不清楚; &a…...
算法leetcode|64. 最小路径和(rust重拳出击)
文章目录 64. 最小路径和:样例 1:样例 2:提示: 分析:题解:rust:go:c:python:java: 64. 最小路径和: 给定一个包含非负整数的 m x n 网…...
css---实现文本超过两行时显示省略号(...)的效果
可以使用CSS中的text-overflow属性配合-webkit-line-clamp属性来实现。以下是一种常见的方式: .text-container {overflow: hidden;display: -webkit-box;-webkit-line-clamp: 2; /* 设置最大显示行数 */-webkit-box-orient: vertical;text-overflow: ellipsis; }在…...
30-使用RocketMQ做削峰处理
1、增加排队功能的思路 在出票模块里,一个消费者拿到了某个车次锁,则该车次下所有的票都由他来出,一张一张的出,知道所有的订单都出完。 2、实现排队出票功能 2.1、 修改发送到MQ消息的内容 修改MQ消息内容,只需要通知出哪天和哪个车次的票(即:组成锁的内容),不需要…...
如何用非root账号安装k8s集群
在大多数情况下,为了安装 Kubernetes(K8s)集群,需要具有root权限或者以root身份执行某些操作,例如安装软件包和配置系统级别的设置。然而,你可以通过以下方法在非root账号下安装K8s集群: 使用Mi…...
windows环境安装elasticsearch+kibana并完成JAVA客户端查询
下载elasticsearch和kibana安装包 原文连接:https://juejin.cn/post/7261262567304298554 elasticsearch官网下载比较慢,有时还打不开,可以通过https://elasticsearch.cn/download/下载,先找到对应的版本,最好使用迅…...
高精度算法
基础模板: (411条消息) 高精度加法_会笑的小熊的博客-CSDN博客 (411条消息) 高精度乘法_会笑的小熊的博客-CSDN博客 (411条消息) 高精度减法_会笑的小熊的博客-CSDN博客 目录 P1601 AB Problem(高精) P1303 A*B Problem P1009 [NOIP1998 普…...
DragGAN:用崭新的方式进行图像处理
该项目的论文被SIGGRAPH 2023 收录,论文以 StyleGAN2 架构为基础,实现了 “Drag” 关键点就能轻松 P 图的效果。 https://github.com/XingangPan/DragGAN https://vcai.mpi-inf.mpg.de/projects/DragGAN/ 目录 原图1测试一测试二测试三 原图2测试一测试…...
语音播放 linux
调整语音音量大小 pactl list sinks pactl set-sink-volume 15 12345 # 15可以改成别的id安装pip install pyttsx3 sudo apt-get update sudo apt-get install espeak sudo ldconfig pip3 install pyttsx3代码 import pyttsx3 import threading def speak_work(text):engine…...
各大互联网公司面经分享:Java 全栈知识 +1500 道大厂面试真题
这篇文章给大家分享一下我遇到的一些质量较高的面试经历,具体经过就不多说了,就把面试题打出来供各位读者老哥参考如有不全的地方,各位海涵。 猿辅导 八皇后问题 求二叉树的最长距离(任意两个节点的路径 中最长的) lru 算法的实现 设计一…...
【LeetCode】剑指offer礼物的最大价值
礼物的最大价值 题目描述算法分析编程代码 链接: 礼物的最大价值 题目描述 算法分析 编程代码 class Solution { public:int maxValue(vector<vector<int>>& grid) {int m grid.size();int n grid[0].size();vector<vector<int>> dp(m1,vector…...
UE5 学习系列(二)用户操作界面及介绍
这篇博客是 UE5 学习系列博客的第二篇,在第一篇的基础上展开这篇内容。博客参考的 B 站视频资料和第一篇的链接如下: 【Note】:如果你已经完成安装等操作,可以只执行第一篇博客中 2. 新建一个空白游戏项目 章节操作,重…...
铭豹扩展坞 USB转网口 突然无法识别解决方法
当 USB 转网口扩展坞在一台笔记本上无法识别,但在其他电脑上正常工作时,问题通常出在笔记本自身或其与扩展坞的兼容性上。以下是系统化的定位思路和排查步骤,帮助你快速找到故障原因: 背景: 一个M-pard(铭豹)扩展坞的网卡突然无法识别了,扩展出来的三个USB接口正常。…...
多模态2025:技术路线“神仙打架”,视频生成冲上云霄
文|魏琳华 编|王一粟 一场大会,聚集了中国多模态大模型的“半壁江山”。 智源大会2025为期两天的论坛中,汇集了学界、创业公司和大厂等三方的热门选手,关于多模态的集中讨论达到了前所未有的热度。其中,…...
C++初阶-list的底层
目录 1.std::list实现的所有代码 2.list的简单介绍 2.1实现list的类 2.2_list_iterator的实现 2.2.1_list_iterator实现的原因和好处 2.2.2_list_iterator实现 2.3_list_node的实现 2.3.1. 避免递归的模板依赖 2.3.2. 内存布局一致性 2.3.3. 类型安全的替代方案 2.3.…...
c++ 面试题(1)-----深度优先搜索(DFS)实现
操作系统:ubuntu22.04 IDE:Visual Studio Code 编程语言:C11 题目描述 地上有一个 m 行 n 列的方格,从坐标 [0,0] 起始。一个机器人可以从某一格移动到上下左右四个格子,但不能进入行坐标和列坐标的数位之和大于 k 的格子。 例…...
el-switch文字内置
el-switch文字内置 效果 vue <div style"color:#ffffff;font-size:14px;float:left;margin-bottom:5px;margin-right:5px;">自动加载</div> <el-switch v-model"value" active-color"#3E99FB" inactive-color"#DCDFE6"…...
【论文笔记】若干矿井粉尘检测算法概述
总的来说,传统机器学习、传统机器学习与深度学习的结合、LSTM等算法所需要的数据集来源于矿井传感器测量的粉尘浓度,通过建立回归模型来预测未来矿井的粉尘浓度。传统机器学习算法性能易受数据中极端值的影响。YOLO等计算机视觉算法所需要的数据集来源于…...
Module Federation 和 Native Federation 的比较
前言 Module Federation 是 Webpack 5 引入的微前端架构方案,允许不同独立构建的应用在运行时动态共享模块。 Native Federation 是 Angular 官方基于 Module Federation 理念实现的专为 Angular 优化的微前端方案。 概念解析 Module Federation (模块联邦) Modul…...
C++使用 new 来创建动态数组
问题: 不能使用变量定义数组大小 原因: 这是因为数组在内存中是连续存储的,编译器需要在编译阶段就确定数组的大小,以便正确地分配内存空间。如果允许使用变量来定义数组的大小,那么编译器就无法在编译时确定数组的大…...
【Go语言基础【13】】函数、闭包、方法
文章目录 零、概述一、函数基础1、函数基础概念2、参数传递机制3、返回值特性3.1. 多返回值3.2. 命名返回值3.3. 错误处理 二、函数类型与高阶函数1. 函数类型定义2. 高阶函数(函数作为参数、返回值) 三、匿名函数与闭包1. 匿名函数(Lambda函…...
