对于老式类,有一个区别:
>>> 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__()。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)