那些也许你不知道的操作符!

2024-02-13 19:44
文章标签 知道 操作符 也许

本文主要是介绍那些也许你不知道的操作符!,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

前言

操作符有很多种,目前我们已经了解了一部分

例如最简单的+、-、*、/、=,还有我们学到的&&,||,!等,但是操作符可不是就只有这么些的,让我们一起来看看吧

目录

1. 移位操作符

原码、反码、补码

1.1 <<左移操作符

1.2 >>右移操作符

2. 位操作符

&按位与

|按位或

^按位异或

~按位取反

3.整型提升


1. 移位操作符

在学习移位操作符前要对二进制有一定的了解

原码、反码、补码

整数的二进制表示方法有三种,分别是原码、反码、补码

原码:直接将正负数按照二进制的形式翻译得到的就是原码

反码:符号位不变,其他位依次按位取反即可(0变1,1变0)

补码:反码 + 1 得到补码

整型int占4个字节,所以一共有32个bit位,可以存放32个0或1

第一个bit位是符号位,如果整数为正,符号位是0,整数为负,符号位是1,剩下的31个bit位正常存放

正整数的原码、反码、补码都是相同的,为原码

例如:整数-5

5转换为二进制为:101,那么它的原码就是:10000000 00000000 00000000 00000101
反码符号位不变,其他按位取反:11111111 11111111 11111111 11111010
补码为反码 + 1 ,11111111 11111111 11111111 11111011

原码取反加1能得到补码,补码也能取反加1得到原码哦

小知识:计算机在内存中对于数据的存储其实存放的都是补码

1.1 <<左移操作符

移位规则:左边抛弃,右边补0

#include <stdio.h>int main()
{int num = 5; //00000000 00000000 00000000 00000101int n = num << 1; //00000000 00000000 00000000 00001010printf("%d", n);return 0;
}
输出结果:10

 这里面其实有个规律,如果我们再次使用左移操作符,得到的为20,再一次得到的是40

#include <stdio.h>int main()
{int num = 5; //00000000 00000000 00000000 00000101int t = 3;while (t--) //t为循环次数{num = num << 1;printf("%d ", num);}return 0;
}

 

从5到10到20到40,我们可以发现它是以2倍的形式增加的

1.2 >>右移操作符

移位规则:左边补符号位,右边抛弃

#include <stdio.h>int main()
{int num = 10; //00000000 00000000 00000000 00001010int n = num >> 1; //00000000 00000000 00000000 00000101printf("%d", n);return 0;
}

这里的规律也是类似

#include <stdio.h>int main()
{int num = 10; //00000000 00000000 00000000 00001010int t = 3;while (t--) //t为循环次数{num = num >> 1;printf("%d ", num);}return 0;
}

 

它是以2为倍数减少的

2. 位操作符

&按位与

规则:将两数补码相比较,有0则0,两者为1才为1,看代码

#include <stdio.h>int main()
{int num1 = 5;   // 5补码:00000000 00000000 00000000 00000101int num2 = -4;	//-4原码:10000000 00000000 00000000 00000100//-4反码:11111111 11111111 11111111 11111011//-4补码:11111111 11111111 11111111 11111100 两者补码按位与// 5补码:00000000 00000000 00000000 00000101//&有0则0:00000000 00000000 00000000 00000100printf("%d\n", num1 & num2); return 0;
}
输出结果:4

最后&出来的结果为补码,原码、反码、补码相同,所以原码结果为4 

|按位或

规则:将两数补码相比较,有1则1,两者为0才为0

#include <stdio.h>int main()
{int num1 = 5;   // 5补码:00000000 00000000 00000000 00000101int num2 = -4;	//-4原码:10000000 00000000 00000000 00000100//-4反码:11111111 11111111 11111111 11111011//-4补码:11111111 11111111 11111111 11111100 两者补码按位与// 5补码:00000000 00000000 00000000 00000101//补码结果:11111111 11111111 11111111 11111101//原码结果:10000000 00000000 00000000 00000011printf("%d\n", num1 | num2); return 0;
}
输出结果:-3

^按位异或

规则:将两数补码相比较,相同为0,相异为1

#include <stdio.h>int main()
{int num1 = 5;   // 5补码:00000000 00000000 00000000 00000101int num2 = -4;	//-4原码:10000000 00000000 00000000 00000100//-4反码:11111111 11111111 11111111 11111011//-4补码:11111111 11111111 11111111 11111100 两者补码按位与// 5补码:00000000 00000000 00000000 00000101//补码结果:11111111 11111111 11111111 11111001//原码结果:10000000 00000000 00000000 00000111printf("%d\n", num1 ^ num2); return 0;
}
输出结果:-7

~按位取反

规则:0变1,1变0

#include <stdio.h>int main()
{printf("%d\n",~1); //1的原码00000000 00000000 00000000 00000001//取反结果11111111 11111111 11111111 11111110//结果原码10000000 00000000 00000000 00000010return 0;
}
输出结果:-2

操作符实践

面试题:不使用第三个变量,实现两数交换

#include <stdio.h>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;
}

 

这里异或我们需要知道,n ^ n = 0 , n ^ 0 = n,上题正是利用了第一个特性

所以我们一个个代入之后就能理解了

这篇关于那些也许你不知道的操作符!的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/706443

相关文章

C++操作符重载实例(独立函数)

C++操作符重载实例,我们把坐标值CVector的加法进行重载,计算c3=c1+c2时,也就是计算x3=x1+x2,y3=y1+y2,今天我们以独立函数的方式重载操作符+(加号),以下是C++代码: c1802.cpp源代码: D:\YcjWork\CppTour>vim c1802.cpp #include <iostream>using namespace std;/*** 以独立函数

C++可以被重载的操作符Overloadable operators

C++允许绝大多数操作符被重载,也就是重新定义操作符实现的功能,这样它们的行为可以被设计出来以适应所有的数据类型,包括类。 以下是C++可以被重载的操作符(Overloadable operators): //四则运算符+ - * / %+= -= *= /= %=//比较运算符> >= == != //赋值运算符= //位操作

c++/《重载操作符》

为什么要对运算符进行重载:         C++预定义中的运算符的操作对象只局限于基本的内置数据类型,但是对于我们自定义的类型(类)是没有办法操作的。但是大多时候我们需要对我们定义的类型进行类似的运算,这个时候就需要我们对这么运算符进行重新定义,赋予其新的功能,以满足自身的需求。 <返回类型说明符> operator <运算符符号>(<参数表>) { <函数体> }

[情商-13]:语言的艺术:何为真实和真相,所谓真相,就是别人想让你知道的真相!洞察谎言与真相!

目录 前言: 一、说话的真实程度分级 二、说谎动机分级:善意谎言、中性谎言、恶意谎言 三、小心:所谓真相:只说对自己有利的真相 四、小心:所谓真相:就是别人想让你知道的真相 五、小心:所谓善解人意:就是别人只说你想要听到的话 前言: 何为真实和真相,所谓真相,就是别人想让你知道的真相!洞察谎言与真相! 人与人交流话语中,处处充满了不真实,完全真实的只是其中一小部分,这

【JavaScript】ES6之...延展操作符

… 操作符(也被叫做延展操作符 - spread operator)已经被 ES6 数组 支持。它允许传递数组或者类数组直接做为函数的参数而不用通过apply。      延展操作符一般用于属性的批量赋值上。    通过分析① test8(…args) ②test8(args) ③ test8.apply(null, args) 易看出区别

看病要排队这个是地球人都知道的常识

归纳编程学习的感悟, 记录奋斗路上的点滴, 希望能帮到一样刻苦的你! 如有不足欢迎指正! 共同学习交流! 🌎欢迎各位→点赞 👍+ 收藏⭐ + 留言​📝唯有付出,才有丰富的果实收获! 看病要排队这个是地球人都知道的常识。 不过经过细心的0068的观察,他发现了医院里排队还是有讲究的。0068所去的医院有三个医生(汗,这么少)同时看病。而看病的人病情有轻重,所以不能根据简单的先来

纳米材料咋设计?蛋白质模块咋用?看这里就知道啦!

大家好,今天我们来了解一项关于蛋白质纳米材料设计的研究——《Blueprinting extendable nanomaterials with standardized protein blocks》发表于《Nature》。蛋白质结构复杂,其组装体的设计颇具挑战。但近期的研究取得了新突破,通过设计标准化的蛋白质模块,如线性、曲线和转角模块等,实现了纳米材料的可扩展性和规律性。这

只有对比,才知道伊利股份半年报的高成色

投资圈有句名言:“当潮水退去的时候,才知道谁在裸泳”。大环境顺风顺水,大家看着都挺好,只有环境变化,才更容易分辨出来,谁才是真有实力。当下,在消费环境弱复苏的大背景下,高成色的半年报业绩让伊利股份的实力一览无余。 8月29日,伊利股份发布中期业绩。上半年,面对严峻复杂的市场环境,伊利直面挑战、主动调整,实现营业总收入599.15亿元,归母净利润75.31亿元,均稳居行业第一。

C语言操作符汇总(上)

目录 前言 一、操作符的分类 二、⼆进制和进制转换 1. 二进制转10进制 2. 10进制转2进制数字 3.  2进制转8进制和16进制 3.1 2进制转8进制 3.2 二进制转16进制  三、原码、反码、补码  四、移位操作符 1. 左移操作符 2. 右移操作符  五、位操作符:&、|、^、~ 1.按位与: 2.按位或:  3.异或 4.按位取反   5.趁热

Flink实战案例(二十三):自定义时间和窗口的操作符(四)window functions之增量聚合函数(一)ReduceFunction

实例一 例子: 计算每个传感器15s窗口中的温度最小值 val minTempPerWindow = sensorData.map(r => (r.id, r.temperature)).keyBy(_._1).timeWindow(Time.seconds(15)).reduce((r1, r2) => (r1._1, r1._2.min(r2._2))) 实例二 ReduceFun