登录
首页 >  文章 >  python教程

Python位运算详解:与或非异或左右移操作符

时间:2026-04-11 15:00:42 302浏览 收藏

本文深入解析Python中易被误解的位运算符(&、|、~、^、>),强调它们是对整数逐位操作的底层工具,而非布尔逻辑运算符——例如5 & 3结果是1而非True,~5等于-6而非简单的0/1翻转,^表示异或而非幂运算(**才是)。文章厘清了算术右移对负数的特殊处理(如-5 >> 1 得 -3)、掩码构造技巧、左/右移与2的幂乘除的关系,并直击高频误区:混淆位运算与逻辑运算、误用异或交换变量、忽视补码机制及符号位陷阱;同时指出位运算的真实价值场景——标志位管理、协议解析、算法优化等,而非日常业务代码中的炫技式滥用,提醒开发者优先保障可读性与正确性。

Python位运算怎么算_与或非异或及左移右移操作符

Python位运算符怎么写:& | ~ ^ > 不是逻辑运算符

Python的&|~^>>全是对整数**逐位操作**的,不是and/or/not那种布尔逻辑。拿错符号会得到完全意外的结果——比如5 & 3算出来是1,不是True

常见错误现象:
• 把&and用,结果条件判断永远不按预期走
• 对负数做~,发现结果不是“取反0/1”,而是补码翻转(~5-6
^被误以为是幂运算(其实是异或,幂运算是**

  • &:同为1才得1 → 6 & 30b110 & 0b011 = 0b010 = 2
  • |:有1就得1 → 6 | 30b110 | 0b011 = 0b111 = 7
  • ^:相同为0,不同为1 → 6 ^ 30b110 ^ 0b011 = 0b101 = 5
  • ~x等价于-x - 1,别硬记规则,直接试:~0-1~1-2

左移和右移>>的本质是乘除2的幂,但有符号位陷阱

左移n位 ≈ 乘以2**n,右移n位 ≈ 除以2**n并向下取整。但Python的右移是**算术右移**,负数高位补1,不是简单丢掉位。

使用场景:
• 快速乘除2的幂(比*///略快,但现代解释器优化后差别极小)
• 构造掩码(如1 得32,即第6位为1)
• 解析二进制协议字段(需配合&提取特定位)

  • 5 → 200b101 → 0b10100
  • 5 >> 210b101 → 0b1
  • -5 >> 1-3(不是-2!因为补码高位补1,保持负号)
  • 要无符号右移?Python没原生支持,得手动转成足够长的正整数再移:(x + (1 > n(假设32位)

位运算常见误用:用^交换变量值不安全

网上常教“不用临时变量交换两个数”:a ^= b; b ^= a; a ^= b。这在C里可行,但在Python里**可能出错**。

原因:
• Python中整数是对象,ab若初始值相等(如都为0),中间步会变成0 ^ 0 = 0,最终全变0
• 更隐蔽的是:如果ab引用同一对象(如a = b = [1]),这种写法根本无效(但整数不可变,所以只影响可变对象场景)

  • 安全做法永远是:a, b = b, a
  • 真想练位运算?改用异或校验或加密小片段,比如data ^ 0xFF做简单字节翻转
  • 注意:异或满足交换律和结合律,a ^ b ^ a == b,这是去重或恢复数据的基础

什么时候该用位运算?别为了炫技硬套

位运算真正有用的地方很具体:处理标志位、解析硬件/网络协议、写底层工具、做算法优化(如树状数组、快速幂)。日常业务代码里,可读性远比省几个纳秒重要。

容易踩的坑:
• 把flag & FLAG_READ写成flag and FLAG_READ → 布尔上下文丢失位信息
• 没检查整数范围,移位超过位宽(Python整数无限长,但对接C库或文件格式时,32/64位截断会出问题)
• 用~代替-x-1却不理解它对负数的意义

  • 判断某位是否为1:用num & (1 ,不是num & n
  • 清零某位:用num & ~(1 (先取反再与)
  • 设置某位:用num | (1
  • 性能提示:纯Python里位运算不比算术运算快多少;瓶颈在算法,不在&还是%

最常被忽略的一点:Python整数没有固定位宽,bin(~5)显示-0b110而不是一串1开头的补码——你看到的是它的数学值,不是内存表示。要模拟固定宽度,得自己用& 0xFF之类掩码截断。

今天带大家了解了的相关知识,希望对你有所帮助;关于文章的技术知识我们会一点点深入介绍,欢迎大家关注golang学习网公众号,一起学习编程~

资料下载
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>