Python 位运算符与位运算

总结:

  1. 位运算符 是 直接对整数在内存中的二进制位进行操作;

Python运算符优先级:

以下表格列出了从最高到最低优先级的所有运算符:

运算符 描述
** 指数 (最高优先级)
~ + - 按位翻转, 一元加号和减号 (最后两个的方法名为 +@ 和 -@)
* / % // 乘,除,取模和取整除
+ - 加法减法
>> << 右移,左移运算符
& 位 'AND'
^ l 位运算符
<= < > >= 比较运算符
<> == != 等于运算符
= %= /= //= -= += = *= 赋值运算符
is is not 身份运算符
in not in 成员运算符
not or and 逻辑运算符

Python算术运算符:

以下假设变量 a为10,变量b为21:

运算符 描述 实例
+ 加 - 两个对象相加 a + b 输出结果 31
- 减 - 得到负数或是一个数减去另一个数 a - b 输出结果 -11
* 乘 - 两个数相乘或是返回一个被重复若干次字串 a * b 输出结果 210
/ 除 - x 除以 y b / a 输出结果 2.1
% 取模 - 返回除法的余数 b % a 输出结果 1
** 幂 - 返回x的y次幂 a**b 为10的21次方
// 取整除 - 返回商的整数部分 9//2 输出结果 4 , 9.0//2.0 输出结果 4.0

一、概述

程序中的所有数在计算机内存中都是以二进制的形式储存的。除了常见的算术运算符+-*/%,还有位运算&|^~>><<,就是直接对整数在内存中的二进制位进行操作。接下来以C语言为例介绍,其它语言大同小异。

Python中的6种位运算符

在Python中,按位运算符有左移运算符(<<)、右移运算符(>>)、按位与运算(&)、按位或运算(|)、按位取反运算(~)、异或运算符,其中按位取反运算符为单目运算符 。

运算符 描述 实例
& 按位与运算符:参与运算的两个值,如果两个相应位都为1,则该位的结果为1,否则为0 (a & b) 输出结果 12 ,二进制解释:0000 1100
| 按位或运算符:只要对应的二个二进位有一个为1时,结果位就为1。 (a | b) 输出结果 61 ,二进制解释:0011 1101
^ 按位异或运算符:当两对应的二进位相异时,结果为1 (a ^ b) 输出结果 49 ,二进制解释:0011 0001
~ 按位取反运算符:对数据的每个二进制位取反,即把1变为0,把0变为1 (~a ) 输出结果 -61 ,二进制解释:1100 0011
<< 左移动运算符:运算数的各二进位全部左移若干位,由"<<"右边的数指定移动的位数,高位丢弃,低位补0。 a << 2 输出结果 240 ,二进制解释:1111 0000
>> 右移动运算符:把">>"左边的运算数的各二进位全部右移若干位,">>"右边的数指定移动的位数 a >> 2 输出结果 15 ,二进制解释:0000 1111

二、运算符操作

1. 按位与(&) ( bitwise and of x and y )

又叫 and 运算,用符号 & 表示,计算方式如下:

`1&1=1` , `0&1=0` , `0&0=0

& 举例:5&3 = 1 解释:101 11 相同位仅为个位1 ,故结果为 1
0 1 1 ---> 3
1 0 1 ---> 5
0 0 1 ---> 1

2. 按位或 (|) ( bitwise or of x and y )

又叫 or 运算,用符号 | 表示,运算方式: 记为: 一真为真,同假为假
1|1=1 , 1|0=1 , 0|0=0

| 举例:5|3 = 7 解释:101 11 出现1的位是 1 1 1,故结果为 111

0 1 1   ---> 3
1 0 1   ---> 5
 --------
1 1 1   ---> 7
3. 按位异或(^)( bitwise exclusive or of x and y )

又叫 xor 运算,用符号 ^ 表示,注意这里不是数学表达里面的次方的意思,运算方式: 记为: 同为假,异为真
1^1=0 , 1^0=1 , 0^0=0

^ 举例:5^3 = 6 解释:101 11 对位相加(不进位)是 1 1 0,故结果为 110

0 1 1    ---> 3
1 0 1    ---> 5
---------
1 1 0    ---> 6
4. 按位反转 (the bits of x inverted )

~ 举例:~5 = -6 解释:将二进制数+1之后乘以-1,即~x = -(x+1),-(101 + 1) = -110

按位反转仅能用在数字前面。所以写成 3+~5 可以得到结果-3,写成3~5就出错了

5. 按位左移 ( x shifted left by n bits )

<< 举例: 5<<2 = 20 解释:101 向左移动2位得到 10100 ,即右面多出2位用0补

6. 按位右移 ( x shifted right by n bits )

>> 举例:5>>2 = 1 解释:101 向右移动2位得到 1,即去掉右面的2位

简单应用
1、交换变量值

异或运算有如下特性:

a^b^a=b , a^b^b=a

因此可以用于程序中的变量值交换,C语言中,我们可能经常这样交换变量值:

`#include  <stdio.h>` 
`int main()`
`{`
`int a =  3, b =  5;`
`int temp;  /*定义一个临时变量用于交换方便*/`
`temp = a;`
`a = b;`
`b = temp;`
`printf("a = %d, b = %d", a, b);  /*输出结果为:a = 5, b = 3 实现了变量值的交换*/`
10.  `}`

但是以后我们可以这样实现:

#include  <stdio.h>`
int main()`
{`
int a =  3, b =  5;`
a ^= b;  /*等同于:a = a ^ b 之后会讲*/`
b = a ^ b;  /*这时 a ^ b 等于 原来 a 的值*/`
a ^= b;  /*a = a ^ b*/`
`printf("a = %d, b = %d", a, b);`
9.  `}

a, b 为负数时同样适用,但位运算只适用于整型,浮点数不可用

2、简单加密
例如,你想传输一条信息给Ta,信息为: `5201314` ,密码为: `1998` ,使用如下代码加密:
5201314  ^  1998`

结果为 `5200492`,想要查看原信息,使用密码查看:

5200492  ^  1998`

这样就生成了原数字: `5201314`.
三、复合赋值符

算术运算中有复合赋值符: +=-+*=/=%=,位运算也有对应的复合赋值: &=|=^=>>=<<=(注意没有 ~= ),运算一样:

a&=b 等价于 a=a&b

以此类推。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,029评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,238评论 3 388
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,576评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,214评论 1 287
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,324评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,392评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,416评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,196评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,631评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,919评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,090评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,767评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,410评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,090评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,328评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,952评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,979评论 2 351

推荐阅读更多精彩内容