python运算符优先级记忆口诀_常用快速记忆技巧与口诀分享

8次阅读

python运算符优先级无需死记口诀,真正需括号的高频陷阱有三:位与和比较混用(x & y == z)、逻辑组合歧义(a and b or c)、取负与幂运算(-x ** 2);应依赖官方文档或ast模块验证,混合运算一律显式加括号。

python运算符优先级记忆口诀_常用快速记忆技巧与口诀分享

Python 运算符优先级不需要死记口诀——它有明确、可验证的规则,且日常编码中真正容易出错的只有少数几处组合。

为什么口诀反而容易误导

所谓“括幂乘除加减左结合”这类口诀,掩盖了真实优先级结构:比如 notand 优先级高,但口诀里根本没提逻辑运算符;又如 Lambda 优先级最低,却常被口诀忽略。更关键的是,Python 官方文档明确列出的 17 级优先级中,多数层级在实际代码中极少引发歧义,真正需要加括号澄清意图的,集中在以下几类。

必须加括号的三类高频陷阱

以下写法看似合理,实则依赖隐式优先级,极易误读或出错:

  • x & y == z → 实际等价于 x & (y == z)(位与优先级低于比较),而非 (x & y) == z,应显式加括号
  • a and b or c → 虽然按 (a and b) or c 执行,但语义模糊,建议改用条件表达式 c if not a else b 或分步赋值
  • -x ** 2 → 结果是 -(x**2)(取负优先级低于幂),不是 (-x)**2,数学直觉在此失效

查优先级比背口诀快得多

遇到不确定时,直接查官方文档或用 ast 模块验证:

立即学习Python免费学习笔记(深入)”;

import ast print(ast.dump(ast.parse('a + b * c', mode='eval'), indent=2))

输出 AST 中会清晰显示 BinOp 的嵌套结构:+ 是外层节点,* 是内层右操作数,印证乘法先于加法。类似地,ast.parse('not a and b') 会显示 BoolOpand 是顶层,not a 是左操作数——说明 not 先作用于 a

真正该养成的习惯

不靠记忆,靠约束:

  • 所有混合运算(尤其含位运算、比较、逻辑、幂)一律加括号,哪怕“理论上不用”
  • ** 时,默认它绑定最紧,-x**22**3**2(右结合)必须意识到结合方向
  • 逻辑运算符只用于布尔上下文,避免 a and b or c 这类“伪三元”,改用 c if not a else b

优先级表本身很稳定,但人对它的直觉常出错。少一次犹豫,就多一次可读性保障。

text=ZqhQzanResources