资讯专栏INFORMATION COLUMN

C语言基础之操作符详解

snowell / 938人阅读

摘要:语言基础之操作符详解操作符的分类算术操作符移位操作符位操作符逻辑操作符逗号表达式表达式求值隐式类型转换算术转换操作符的属性今天就带各位大佬来了解一波语言的操作符。


xwg今天就带各位大佬来了解一波C语言的操作符。

操作符的分类

常见的操作符分别如下:

  1. 算术操作符
  2. 移位操作符
  3. 位操作符
  4. 逻辑操作符
  5. 逗号表达式

算术操作符

算术操作符是我们最常用的操作符:+ - * / %
注:

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

移位操作符

移位操作符分为左移操作符和右移操作符,移位操作符的操作对象只能是整数,且所谓的移位是对于整数的二进制位进行移位:
左移操作符:<<
右移操作符:>>

  1. 左移操作符:
    移位规则:左边抛弃,右边补0
  2. 右移操作符:
    移位规则:
    2.1 逻辑移位
    左边用0填充,右边丢弃
    2.2算术移位
    左边用原该值的符号位填充,右边丢弃
    注:大部分编译器右移都是执行算术右移。

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

位操作符

位操作符有:

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

位操作符的操作数必须是整数,且是对其二进制的补码进行操作。
异或的基本性质:

  1. 0异或上任何数为其本身:0^2=2
  2. 任何数异或上其本身等于0:2^2=0

例:不创建临时变量使两个数进行交换

#include int main(){ int a = 10; int b = 20; a = a^b; b = a^b; a = a^b; printf("a = %d b = %d/n", a, b); return 0;}

逻辑操作符

逻辑操作符分为:

&& —— 逻辑与
|| —— 逻辑或

逻辑与:
必须使 && 左右两个表达式都为真

逻辑或:
|| 两边有一个式子为真即为真

逗号表达式

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

表达式求值

表达式求值的顺序一部分是由操作符的优先级和结合性决定,但是,有些表达式的操作数在求值的过程中可能需要转换为其他类型。

隐式类型转换

C语言的整型算术运算总是至少以缺省整型类型的精度来进行的,为了获得这个精度,表达式中的字符和短整型操作数在使用之前被转换为普通整型,这种转换称为整型提升。

实例:

char a,b,c;...a = b + c;

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

整形提升是按照变量的数据类型的符号位来提升的,若操作对象为正数则补0,操作对象为负数则补1。

负数的整形提升
char c1 = -1;
变量c1的二进制位(补码)中只有8个比特位:
1111111
因为 char 为有符号的 char
所以整形提升的时候,高位补充符号位,即为1
提升之后的结果是:
11111111111111111111111111111111

正数的整形提升
char c2 = 1;
变量c2的二进制位(补码)中只有8个比特位:
00000001
因为 char 为有符号的 char
所以整形提升的时候,高位补充符号位,即为0
提升之后的结果是:
00000000000000000000000000000001

无符号整形提升,高位补0

int main(){	char a = 5;  //存在char、short计算时发生整形提升	//00000000000000000000000000000101	//截断后	//00000101 - a	//整型提升后(整形提升是按照变量的数据类型的符号位来提升的)	//00000000000000000000000000000101	char b = 126;	//00000000000000000000000001111110	//01111110 - b	//整型提升后	//00000000000000000000000001111110	char c = a + b;	//00000000000000000000000000000101	//00000000000000000000000001111110	//00000000000000000000000010000011	//11111011 - c	//整形提升后	//11111111111111111111111110000011 - 补码	//11111111111111111111111110000010 - 反码	//10000000000000000000000001111101 - 原码	printf("%d/n", a + b);}

算术转换

如果某个操作符的各个操作数属于不同的类型,那么除非其中一个操作数的转换为另一个操作数的类型,否则操作就无法进行。

下面的层次体系称为寻常算术转换:

long double
double
float
unsigned long int
long int
unsigned int
int

如果某个操作数的类型在上面这个列表中排名较低,那么首先要转换为另外一个操作数的类型后执行运算。

操作符的属性

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

  1. 操作符的优先级
  2. 操作符的结合性
  3. 是否控制求值顺序。

两个相邻的操作符先执行哪个?取决于他们的优先级。如果两者的优先级相同,取决于他们的结合性。

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/123614.html

相关文章

  • C语言移位作符、位作符详解

    摘要:目录移位操作符移位操作符位操作符位操作符移位操作符分为左移操作符和右移操作符。左移操作符移位规则左边抛弃,右边补。算数移位和逻辑移位。 目录 1、移位操作符 2、位操作符 1、移位操作符 分为左移操作符(>>)和右移操作符(1逻辑移位的得到的是什么吧~   因为最高位是0,所以最后的结果就...

    NeverSayNever 评论0 收藏0
  • 卷积神经网络(CNN)一维卷积、二维卷积、三维卷积详解

    摘要:一维卷积常用于序列模型,自然语言处理领域。三维卷积这里采用代数的方式对三维卷积进行介绍,具体思想与一维卷积二维卷积相同。 由于计算机视觉的大红大紫,二维卷积的用处范围最广。因此本文首先介绍二维卷积,之后再介绍一维卷积与三维卷积的具体流程,并描述其各自的具体应用。1、二维卷积 •   图中的输入的数据维度为 14 × 14 ,过滤器大小为 5 × 5,二者做卷积,输出的数据维度为 10 × 1...

    renweihub 评论0 收藏0
  • 图解AQS原理ReentrantLock详解-公平锁

    摘要:概述前面已经讲解了关于的非公平锁模式,关于非公平锁,内部其实告诉我们谁先争抢到锁谁就先获得资源,下面就来分析一下公平锁内部是如何实现公平的如果没有看过非公平锁的先去了解下非公平锁,因为这篇文章前面不会讲太多内部结构,直接会对源码进行分析前文 概述 前面已经讲解了关于AQS的非公平锁模式,关于NonfairSync非公平锁,内部其实告诉我们谁先争抢到锁谁就先获得资源,下面就来分析一下公平...

    Taonce 评论0 收藏0
  • Linux 虚拟网络设备详解 “vRouter”

    摘要:不过我们不做那么深究的讨论,简化问题,系统实际上没有实现相关的虚拟路由器设备,自然也没有工具可以操作路由器,因为本身就是一台路由器。 本文首发于我的公众号 cloud_dev,专注于干货分享,号内有大量书籍和视频资源,后台回复「1024」即可领取,欢迎大家关注,二维码文末可以扫。 这篇文章继上篇文章 Linux 虚拟网络设备详解之 Bridge,上篇发表之后,有读者问我这样一个问题: ...

    lastSeries 评论0 收藏0
  • Linux 虚拟网络设备详解 “vRouter”

    摘要:不过我们不做那么深究的讨论,简化问题,系统实际上没有实现相关的虚拟路由器设备,自然也没有工具可以操作路由器,因为本身就是一台路由器。 本文首发于我的公众号 cloud_dev,专注于干货分享,号内有大量书籍和视频资源,后台回复「1024」即可领取,欢迎大家关注,二维码文末可以扫。 这篇文章继上篇文章 Linux 虚拟网络设备详解之 Bridge,上篇发表之后,有读者问我这样一个问题: ...

    HitenDev 评论0 收藏0

发表评论

0条评论

snowell

|高级讲师

TA的文章

阅读更多
最新活动
阅读需要支付1元查看
<