对于老式类,有一个区别:
>>> class X: pass
...
>>> type(X)
<type 'classobj'>
>>> X.__class__
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
AttributeError: class X has no attribute '__class__'
>>> x = X()
>>> x.__class__
<class __main__.X at 0x171b5d50>
>>> type(x)
<type 'instance'>
新型类的重点在于统一类和类型。从技术上讲,这__class__
是唯一适用于新旧类实例的解决方案,但也会对旧类对象本身抛出异常。您可以调用type()
任何对象,但不是每个对象都具有__class__
。另外,您可以以__class__
一种无法与之混为一谈的方式与之混为一谈type()
。
>>> class Z(object):
... def __getattribute__(self, name):
... return "ham"
...
>>> z = Z()
>>> z.__class__
'ham'
>>> type(z)
<class '__main__.Z'>
就个人而言,我通常只有一个带有新样式类的环境,就样式而言type()
,我倾向于使用它,因为当它们存在时,我通常更喜欢内置函数而不是使用魔术属性。举例来说,我也宁愿bool(x)
到x.__nonzero__()
。