电话
400 9058 355
len() 只调用 __len__() 而不调用 __bool__(),因其实现机制完全不检查 __bool__();必须定义返回非负整数的 __len__() 才能支持 len()。
len() 会调用
__len__() 而不是 __bool__()
len() 是 Python 的内置函数,它**只认 __len__() 方法**,完全不看 __bool__() 或 __nonzero__()。所谓“通过 __bool__ 误导 len”是常见误解——len() 根本不会尝试 fallback 到布尔方法。如果你没定义 __len__(),直接调 len(obj) 就会抛 TypeError: object of type 'X' has no len(),不会绕道去查 __bool__()。
len():必须实现 __len__()
要让一个类支持 len(),唯一合法方式是定义 __len__() 方法,并返回一个非负整数(int)。Python 明确要求该方法返回 int,返回 float、str 或其他类型都会触发 TypeError。
__len__() 必须返回 int,不能是 None 或负数(否则运行时报 ValueError)__bool__() 和 __len__() 可以共存,但互不影响:比如空容器可返回 len() == 0 且 bool() == False,但这是你主动设计的语义,不是语言自动关联的class Stack:
def __init__(self):
self._items = []
def __len__(self):
return len(self._items) # ✅ 正确:返回 int
def __bool__(self):
return len(self._items) > 0 # ✅ 可选:独立控制 bool 行为
__bool__ 能替代 __len__
有人尝试删掉 __len__(),只留 __bool__() 并期望 len(obj) 返回 0 或 1,这行不通。下面代码会直接崩溃:
class BadExample:
def __bool__(self):
return False
len(BadExample()) # ❌ TypeError: object of type 'BadExample' has no len()
还有人试图在 __bool__() 里偷偷算长度并缓存,再让 len() 去读这个缓存——但因为 len() 根本不调用 __bool__(),这个缓存永远不会被初始化,反而引入竞态或未定义行为。
len() 表达的是“有多少个元素”,bool() 表达的是“是否被认为是非空/真值”。二者语义不同,强行绑定会导致直觉错乱。例如:
len() 应该返回行数(或列数),而 bool() 可能返回 True(因存在非零值)__len__() 可能需要触发实际计算,而 __bool__() 可以快速检查头几个元素是否存在所以,不要为了省一个方法而牺牲清晰性。该写 __len__() 就写,它的存在本身就是在声明:“这个对象有明确定义的长度概念”。
邮箱:8955556@qq.com
Q Q:8955556
本文详解如何将Go官方present工具(用于生成HTML5...
PySNMP在不同版本中对SNMP错误状态(errorSta...
time.Sleep仅阻塞当前goroutine,其他gor...
PHPfopen()创建含特殊符号的文件名失败主因是操作系统...
WooCommerce中通过代码为分组产品动态聚合子商品的属...
io.ReadFull返回io.ErrUnexpectedE...
本文详解Yii2中控制器向视图传递ActiveRecord数...
本文详解为何通过wp_set_object_terms()为...
Pytest中使用@mock.patch类装饰器会导致补丁泄...
带缓冲的channel是并发安全的FIFO队列;make(c...