↓
上期回顾: 【C语言回顾】函数递归
个人主页:C_GUIQU
专栏:【C语言学习】
↑
前言
各位小伙伴大家好!上期小编给大家讲解了C语言中的函数递归,接下来详细讲讲操作符!
1. 操作符分类
- 算术操作符: + 、- 、* 、/ 、%
- 移位操作符: << 、>>
- 位操作符: &、 | 、^
- 赋值操作符: = 、+= 、 -= 、 *= 、 /= 、%= 、<<= 、>>= 、&= 、|= 、^=
- 单⽬操作符: !、++、–、&、*、+、-、~ 、sizeof、(类型)
- 关系操作符: > 、>= 、< 、<= 、 == 、 !=
- 逻辑操作符: && 、||
- 条件操作符: ? :
- 逗号表达式: ,
- 下标引用: []
- 函数调用:()
- 结构成员访问:. 、->
由于有⼀些操作符和⼆进制有关,所以我们先铺垫⼀下二进制和进制转换的知识。
2. 二进制和进制转换
2.1 二进制
- 2进制中满2进1
- 2进制的数字每⼀位都是0~1的数字组成
2.2 进制转换
2.2.1 二进制转十进制
【方法】基数乘以指数的n次方,以 2 为指数,进制值所在的位置为n(从0开始算起),进制值本身为基数。
【举例】
如下面列子:1010就是基数,其进制值的位置就是n。
2.2.2 二进制转八进制
【方法】
【举例】
2.2.3 二进制转十六进制
【方法】
- 从二进制数的最右边开始,将二进制数每四位分为一组。如果最左边的组不足四位,则在前面补零以使其成为四位。
- 将每组四位二进制数转换为其对应的十六进制数。
- 将所有十六进制数字连在一起,得到最终的十六进制数。
【举例】
3. 原码、反码、补码
【整数的2进制表示方法】原码、反码和补码
【符号位和数值位】2进制序列中,最⾼位的1位是被当做符号位(0正1负),剩余的都是数值位。
【概念】
- 原码:直接将数值按照正负数的形式翻译成⼆进制得到的就是原码。
- 反码:将原码的符号位不变,其他位依次按位取反就可以得到反码。
- 补码:反码+1就得到补码。
【性质】
- 正整数的原、反、补码都相同。
- 负整数的三种表示方法各不相同。
- 补码得到原码也是可以使用“取反,+1”的操作。
- 对于整形来说:数据存放内存中其实存放的是补码。
4. 移位操作符
4.1 左移操作符
【移位规则】左边抛弃、右边补0
#include <stdio.h>
int main()
{
int num = 10;
int n = num<<1;
printf("n= %d\n",n);
printf("num= %d\n",num);
return 0;
}
4.2 右移操作符
【移位规则】
- 逻辑右移:左边⽤0填充,右边丢弃。
- 算术右移:左边⽤原该值的符号位填充,右边丢弃
#include <stdio.h>
int main()
{
int num = 10;
int n = num>>1;
printf("n= %d\n",n);
printf("num= %d\n",num);
return 0;
}
【警告】对于移位运算符,不要移动负数位,这个是标准未定义的。
5. 位操作符
& //按位与
| //按位或
^ //按位异或
~ //按位取反
//操作数都必须是整数
【示例】
#include <stdio.h>
int main()
{
int num1 = -