常用C语言操作符

算数操作符

+   -   *   /     %

1、除了%操作符之外,其他的几个操作符可以用于整数和浮点数。
2、对于/操作符如果两个操作数都为整数,执行整数触发。而只要有浮点数执行的就是浮点数除法。
3、%操作符的两个数必须为整数。返回的是整数之后的余数。

printf("%f\n",(float)5/2);
printf("%f\n",5/(float)2);
printf("%f\n",(float)(5/2));
printf("%f\n",5/2.0);
printf("%f\n",2/5);

这段代码的执行结果为:
在这里插入图片描述

位移操作符

<< 左移操作符 ; >>右移操作符

左移操作符位移规则:

对于操作a<<n,
1 按照二进制值每位向高位(书写上是向左)移动n位;
2 最高位(最左边的)n位舍去;
3 最低位(最右边)填加n个0.
即:左边抛弃、右边补0

右移操作符位移规则

右移运算分为两种:
1、逻辑位移,左边用0填充,右边丢弃
2、算数位移,左边用原该值的符号位填充,右边丢弃
如果符号位原来为1(即负数),则左边移入0还是1,要取决于所用的计算机系统。有的系统移入0,有的系统移入1。移入0的称为“逻辑移位”,即简单移位;移入1的称为“算术移位”。

对于位移运算符,不要移动负数位,这个标准是未定义的。

位操作符

&      按位与
|      按位或
^      按位异或

赋值操作符

复合赋值符

+=
-=
*=
/=
%=
>>=
<<=
&=
|=
^=

这些运算符都可以写成复合的效果

单目操作符

 !        逻辑反操作
 -        负值
 +        正值
 &        取地址
sizeof    操作数的类型长度
~         对一个数的二进制按位取反
  - -     前置、后置- -
  ++      前置、后置++
  *       间接访问操作符(解引用操作符)
(类型)   强制类型转换

关系操作符

>
>=
<
<=
!=    用于测试不相等
==    用于测试相等

逻辑操作符

逻辑操作符有:

&&    逻辑与
||    逻辑或

区分逻辑与和按位与,区分逻辑或和按位或

1&2----------->0
1&&2--------->1
1|2------------>3
1||2----------->1

逻辑与和或的特点
有以下代码:

#include <stdio.h>
int main()
{
    int i = 0,a=0,b=2,c =3,d=4;
    i = a++ && ++b && d++;
    //i = a++||++b||d++;
    printf("a = %d\n b = %d\n c = %d\nd = %d\n", a, b, c, d);
    return 0; }

它的输出结果是:
在这里插入图片描述
当 i = a++||++b||d++;时运行结果如下:
在这里插入图片描述

条件操作符

exp1 ? exp2 : exp3

有如下代码来比较两个数的大小

#include <stdio.h>
int Max(int a, int b)
{
	return a > b ? a : b;
}
int main()
{
	printf("%d\n",Max(5,2));
	system("pause");
	return 0;
}

运行结果如下:
在这里插入图片描述

逗号表达式

exp1,exp2,exp3,…expN
逗号表达式,就是用逗号隔开多个表达式。逗号表达式,从左向右依次执行。整个表达式的结果。

int a = 1;
	int b = 2;
	int c = (a>b, a = b + 10, a, b = a + 1);//逗号表达式

这段代码的输出c的结果为3

下标引用、函数调用和结构成员

1、[]下标引用操作符
操作数:一个数组名+一个索引值
2、()函数调用操作符接受一个或多个操作数:第一个操作数是函数名,剩余的操作数就是传递给函数的参数
3、访问一个结构的成员

.结构体.成员名
->结构体指针->成员名

表达式求值

表达式求值的顺序一部分是由操作符的优先级和结合性决定。
同样,有些表达式的操作数在求值的过程中可能需要转换为其他类型。
隐式类型转换
C的整型算术运算总是至少以缺省整型类型的精度来进行的。
为了获得这个精度,表达式中的字符和短整型操作数在使用之前被转换为普通整型,这种转换称为整型提升。
整型提升的意义:
表达式的整型运算要在CPU的相应运算器件内执行,CPU内整型运算器(ALU)的操作数的字节长度一般就是int
的字节长度,同时也是CPU的通用寄存器的长度。
因此,即使两个char类型的相加,在CPU执行时实际上也要先转换为CPU内整型操作数的标准长度。
通用CPU(general-purpose CPU)是难以直接实现两个8比特字节直接相加运算(虽然机器指令中可能有这种
字节相加指令)。所以,表达式中各种长度可能小于int长度的整型值,都必须先转换为int或unsigned int,然
后才能送入CPU去执行运算。
//实例1
char a,b,c;

a = b + c; b和c的值被提升为普通整型,然后再执行加法运算。
加法运算完成之后,结果将被截断,然后再存储于a中。

操作符属性

复杂表达式的求值有三个影响的因素。

  1. 操作符的优先级
  2. 操作符的结合性
  3. 是否控制求值顺序。
    两个相邻的操作符先执行哪个?取决于他们的优先级。如果两者的优先级相同,取决于他们的结合性。
    操作符优先级
操作符描述用法示例结果类型结合性是否控制求值顺序
()聚组(表达式)与表达式同N/A
()函数调用rexp(rexp,…,rexp)rexpL-R
[ ]下标引用rexp[rexp]lexpL-R
.访问结构成员lexp.member_namelexpL-R
->访问结构指针成员rexp->member_namelexpL-R
++后缀自增lexp ++rexpL-R
后缀自减lexp –rexpL-R
!逻辑反! rexprexpR-L
~按位取反~ rexprexpR-L
+单目,表示正值+ rexprexpR-L
-单目,表示负值- rexprexpR-L
++前缀自增++ lexprexpR-L
前缀自减– lexprexpR-L
*间接访问* rexplexpR-L
&取地址& lexprexpR-L
sizeof取其长度,以字节表示sizeof rexp sizeof(类 型)rexpR-L
(类 型)类型转换 (类型)rexprexpR-L
*乘法rexp * rexprexpL-R
/除法rexp / rexprexpL-R
%整数取余rexp % rexprexpL-R
+加法rexp + rexprexpL-R
-减法rexp - rexprexpL-R
<<左移位rexp << rexprexpL-R
>>右移位rexp >> rexprexpL-R
>大于rexp > rexprexpL-R
>=大于等于rexp >= rexprexpL-R
<小于rexp < rexprexpL-R
<=小于等于rexp <= rexprexpL-R
==等于rexp == rexprexpL-R
!=不等于rexp != rexprexpL-R
&位与rexp & rexprexpL-R
^位异或rexp ^ rexprexpL-R 否
1位或rexp 1 rexprexpL-R
&&逻辑与rexp && rexprexpL-R
11逻辑或rexp 11rexprexpL-R
? :条件操作符rexp ? rexp : rexprexpN/A
=赋值lexp = rexprexpR-L
+=以…加lexp += rexprexpR-L
-=以…减lexp -= rexprexpR-L
*=以…乘lexp *= rexprexpR-L
/=以…除lexp /= rexprexpR-L
%=以…取模lexp %= rexprexpR-L
<<=以…左移lexp <<= rexprexpR-L
>>=以…右移lexp >>= rexprexpR-L
&=以…与lexp &= rexprexpR-L
^=以…异或lexp ^= rexprexpR-L
1=以…或lexp 1= rexprexpR-L
逗号rexp,rexprexpL-R

以上表中1代表 |

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值