一、操作符的基本类型及用法
(1)算术操作符
一般包括“+”,“-”,“*”,“%" ,“/”。
注意:“/”在求float的商时,分子或分母要有一个float类型。
(2)移位操作符
“<<" 左移操作符 ,“>>” 右移操作符。
使用:
#include<stdio.h>
#include <stdlib.h>
int main()
{
int a = 3;
//00000000000000000000000000000011 //-二进制序列
int b = -3;
//10000000000000000000000000000011 //-二进制序列
int c1= a << 1;
//左移n位,右边空位补0;
//00000000000000000000000000000110----补码
//00000000000000000000000000000110----原码即 6
int c2= a >> 1;
//
//右移分为算术右移和逻辑右移,取决于编译器
//算术右移:向右移n位,左边根据符号位补“0”或“1”
//逻辑右移:向右移n位,左边补“0”;
int d1 = b << 1;
int d2 = b >> 1;
//10000000000000000000000000000011 //二进制
//11111111111111111111111111111011 // 补码
//11111111111111111111111111111101 // 补码
//10000000000000000000000000000010 //原码 即 -2 说明此编译器是算术右移
//
printf("c1=%d\n", c1);
printf("c2=%d\n", c2);
printf("d1=%d\n", d1);
printf("d2=%d\n", d2);
system("pause");
return 0;
}
结果:
(3)位操作符
& //按位与
| //按位或
^ //按位异或
注:他们的操作数必须是整数
在我上一篇博客有写到可以参考
查看: 位操作符的使用
(4)赋值操作符
+= 、-=、*=、/=、%=、 >>=、 <<=、&=、、|=、^=
(5)单目操作符
! 逻辑反操作
- 负值
+ 正值
& 取地址
sizeof 操作数的类型长度(以字节为单位)
~ 对一个数的二进制按位取反
- - 前置、后置--
+ + 前置、后置++
* 间接访问操作符(解引用操作符)
(类型) 强制类型转
单目操作符的操作数只有一个。
对&,*的使用:
对sizeof的理解:
(6)关系操作符
>、>=、<、<=、
!= 用于测试“不相等”
== 用于测试“相等
注意:敲代码时判断等于是两个“=”。
(7)逻辑操作符
&& 逻辑与
|| 逻辑或
详情看连接:逻辑运算法
(8)条件操作符
exp1 ? exp2 : exp3
条件操作符的运用:
(9)逗号表达式
exp1, exp2, exp3, …expN
逗号表达式,就是用逗号隔开的多个表达式。 逗号表达式,从左向右依次执行。整个表达式的结果是最后一个表达 式的结果。
(10)下标引用、函数调用和结构成
int arr[10];//创建数组
arr[9] = 10;//实用下标引用操作符。
[ ]的两个操作数是arr和9。
二、表达式求值及操作符的属性
(一)表达式求值
表达式求值的顺序一部分是由操作符的优先级和结合性决定。
同样,有些表达式的操作数在求值的过程中可能需要转换为其他类型。 隐式类型转换
C的整型算术运算总是至少以缺省整型类型的精度来进行的。
为了获得这个精度,表达式中的字符和短整型操作数在使用之前被转换为普通整型,这种转换称为整型提升。
(二)整型提升的意义:
表达式的整型运算要在CPU的相应运算器件内执行,CPU内整型运算器(ALU)的操作数的字节长度一般就是int 的字节长度,同时也是CPU的通用寄存器的长度。 因此,即使两个char类型的相加,在CPU执行时实际上也要先转换为CPU内整型操作数的标准长度。 通用CPU(general-purpose CPU)是难以直接实现两个8比特字节直接相加运算(虽然机器指令中可能有这种 字节相加指令)。所以,表达式中各种长度可能小于int长度的整型值,都必须先转换为int或unsigned int,然 后才能送入CPU去执行运算。
(三)复杂表达式的求值有三个影响的因素。
- 操作符的优先级
- 操作符的结合性
- 是否控制求值顺序。
两个相邻的操作符先执行哪个?取决于他们的优先级。如果两者的优先级相同,取决于他们的结合性。
操作符优先级