【C语言极简自学笔记】重讲运算符

一、算术操作符

算术操作符 描述
+ 把两个操作数相加
- 第一个操作数减去第二个操作数
* 把两个操作数相乘
/ 分子除以分母
% 取模运算符,整除后的余数

注意: 1.除号的两端都是整数的时候执行的是整数的除法,两端只要有一个浮点数,就执行浮点数 的除法;

2.%取模两端必须为整数 。

二、移位操作符

1.左移位操作符<<

规则:左边抛弃,右边补0

由于在计算机中存储的数为二进制的补码,正数的原码、反码、补码均一致,负数的补码等于反码加一

则7的原码、补码、反码为:00000000000000000000000000000111

经过左移一位之后的结果为:000000000000000000000000000001110

即为十进制数14

若操作数为负数

-7的原码为:10000000000000000000000000000111

反码为:11111111111111111111111111111000

补码为:11111111111111111111111111111001

左移一位后的结果为:11111111111111111111111111110010

原码为:10000000000000000000000000001110,即十进制数-14

2.右移操作符>>

右移操作符分为两种①:算术移位:右边抛弃,左边补原值符号位

②:逻辑移位:右边抛弃,左边补0

一般编译器均为算术移位

-7的补码为:11111111111111111111111111111001

右移一位后的结果为:11111111111111111111111111111100

原码为:10000000000000000000000000000100,即十进制数-4

7的原码、补码、反码为:00000000000000000000000000000111

右移一位后的结果为: 00000000000000000000000000000011,即十进制数3

三、位操作符

位操作符主要分为三类:

&:按(二进制)位与

|:按(二进制)位或

^:按(二进制)位异或

注意❗❗❗:操作数均为整数

原理:通过存储在计算机中的二进制数进行按位操作,若操作数为正数,则直接输出其对应的数值;若操作数为负数,则求得其对应的原码所代表的数值后输出。

cs 复制代码
int main()
{
	int a = 3;
	//a的补码  00000000000000000000000000000011
	int b = -5;
	//b的原码  10000000000000000000000000000101
	//b的反码  11111111111111111111111111111010
	//b的补码  11111111111111111111111111111011
	int c = a & b;
	printf("c = %d\n",c);
	//a和b的补码按位与结果:00000000000000000000000000000011    即十进制数3
	int d = a | b;
	printf("d = %d\n", d);
	//a和b的补码按位或结果:11111111111111111111111111111011
	//反码为:11111111111111111111111111111010
	//原码为:10000000000000000000000000000101  即十进制数 -5
	int e = a ^ b;
	printf("e = %d\n", e);
	//a和b的补码按位异或结果:11111111111111111111111111111000
	//反码为:11111111111111111111111111110111
	//原码为:10000000000000000000000000001000   即十进制数 -8
	return 0;
}

四、赋值操作符

运算符 描述
= 赋值运算符,把右边操作数的值赋给左边操作数
+= 加且赋值运算符,把右边操作数加上左边操作数的结果赋值给左边操作数
-= 减且赋值运算符,把左边操作数减去右边操作数的结果赋值给左边操作数
*= 乘且赋值运算符,把右边操作数乘以左边操作数的结果赋值给左边操作数
/= 除且赋值运算符,把左边操作数除以右边操作数的结果赋值给左边操作数
%= 求模且赋值运算符,求两个操作数的模赋值给左边操作数
<<= 左移且赋值运算符
>>= 右移且赋值运算符
&= 按位与且赋值运算符
^= 按位异或且赋值运算符
|= 按位或且赋值运算符
相关推荐
许泽宇的技术分享41 分钟前
AudioNotes:当FunASR遇见Qwen2,音视频转笔记的技术革命
笔记·音视频
蒙奇D索大41 分钟前
【数据结构】图论核心应用:关键路径算法详解——从AOE网到项目管理实战
数据结构·笔记·学习·考研·算法·图论·改行学it
Olrookie1 小时前
若依前后端分离版学习笔记(十八)——页面权限,页签缓存以及图标,字典,参数的使用
vue.js·笔记·学习
He BianGu1 小时前
【笔记】在WPF中Decorator是什么以及何时优先考虑 Decorator 派生类
笔记·wpf
weixin_417257061 小时前
Qt解决不同线程,调用对方的函数
开发语言·qt
wan5555cn1 小时前
AI视频生成技术:从想象到现实的视觉革命
人工智能·笔记·深度学习·算法·音视频
梦终剧2 小时前
【Android之路】 Kotlin 的 data class、enum class、sealed interface
android·开发语言·kotlin
半夏知半秋2 小时前
基于skynet框架业务中的gateway实现分析
服务器·开发语言·后端·学习·gateway
Leo655358 小时前
JDK8 的排序、分组求和,转换为Map
java·开发语言
磨十三9 小时前
C++ 标准库排序算法 std::sort 使用详解
开发语言·c++·排序算法