前言
一.算术操作符
1. 基本的算术运算符
1.除了% 意外,其他的操作符都可以作用于整数或浮点数
- / 只要有一个操作数为浮点数,那么进行的是浮点数运算。
如果进行除运算的两个数为是整数,则运算结果为整数,小数部分被舍弃
3.% 作用的两个数必须为整数,得出的余数也为整数。当参与模的运算的两个整数的正负号不同时,运算结果的符号与被除数相同。
如
2.自增运算符和自减运算符
前置++或-- 是先把变量+1或-1,再使用
后置++ 或-- 是先使用变量,再+1或-1
二.移位操作符
左移位操作符规则:
a.左边去除,右边补0
b.左移n位实际就是把原数乘以2的n次方
右移操作符的规则:
1.无符号数进行右移操作时,高位补0,称为逻辑右移
2.有符号位进行右移时,高位补符号位(符号为1就补1,为0就补0),称为算术右移(对于有符号位来说,最左边为符号位,1表示负数,0表正数)
3.右移就是把左边的运算数个二进制位全部右移若干位,右移n位,实际是除以2的n次方
算术右移
逻辑右移:
注意:
对于位运算符中,不要移动负数位,这是标准未定义的,例如:
int num=10;
num>>-1;//这是错误的
位操作符
位的操作符有
注意:它们的操作数只作用于整数
&(按位与):两个操作数对应的二进制位都是1时,结果为1
|(按位或):两个操作数对应的二进制位中有一个是1,结果就为1;
^(按位异或): 两个操作数对应的二进制位相同,结果就为0,不同为1;
~(取反):操作数每个二进制位都取反,即0变为1,1变为0
面试题:
不能创建临时变量(第三个变量),实现两个数的交换。
解析:当两个相同的数异或为0,0异或一个数为该数的值
如
练习:
编写代码实现:求一个整数存储在内存中的二进制中1的个数。
三. sizeof运算符
sizeof(运算对象)
该操作符是获得运算对象占用的内存空间的字节数,结果是整数类型。
运算对象可以是数据类型关键字,常量,变量,表达式
问:
(1)、(2)两个地方分别输出多少?
(3)、(4)两个地方分别输出多少?
四.逻辑操作符
! 逻辑反操作
&& 逻辑与,两边的的值或表达式为真则为真
|| 逻辑或,两边的值或表达式中有一个为真则为真
笔试题
五.逗号表达式
从左到右的顺序依次计算各个表达式的值
x=5+3,5-3 //表达式运算后,表达式的值是2,变量x的值为8
x=(5+3,5-3) // 该表达式是赋值表达式,将逗号表达式的结果2赋值给变量x
int a = 1;
int b = 2;
int c = (a>b, a=b+10, a, b=a+1);
c是多少?
答案; 13
六. 整形提升
表达式中的字符和短整型都需要将它转换为为整形后才能运算,也就是char类型和short int转换为 int
负数的整形提升
char c1 = -1;
变量c1的二进制位(补码)中只有8个比特位:
1111111
因为 char 为有符号的 char
所以整形提升的时候,高位补充符号位,即为1
提升之后的结果是:
11111111111111111111111111111111
正数的整形提升
char c2 = 1;
变量c2的二进制位(补码)中只有8个比特位:
00000001
因为 char 为有符号的 char
所以整形提升的时候,高位补充符号位,即为0
提升之后的结果是:
00000000000000000000000000000001
无符号整形提升,高位补0
我们先来看一道题
答案式: -126
七.自动类型转换
如果有两个不同类型的操作数进行双目运算时,则需要把其中的一个或两个进行转换类型
long double >double> float> unsigned long> long>ungsigned int > int
如果存在long double,则需要把另一个变为 long double类型,否则就是double 以此类推 ,如果以上都没有,则两个数都转换为int
转载:https://blog.csdn.net/sjp11/article/details/116115728