In Python 2, type and class are not the same thing, specifically, for old-style classes, type(obj)
is not the same object as obj.__class__
. So it is possible because instances of old-style classes are actually of a different type (instance
) than their class:
>>> class A(): pass
>>> class B(A): pass
>>> b = B()
>>> assert b.__class__ is B
>>> issubclass(b.__class__, A) # same as issubclass(B, A)
True
>>> issubclass(type(b), A)
False
>>> type(b)
<type 'instance'>
>>> b.__class__
<class __main__.B at 0x10043aa10>
This is resolved in new-style classes:
>>> class NA(object): pass
>>> class NB(NA): pass
>>> nb = NB()
>>> issubclass(type(nb), NA)
True
>>> type(nb)
<class '__main__.NB'>
>>> nb.__class__
<class '__main__.NB'>
Old-style class is not a type, new-style class is:
>>> isinstance(A, type)
False
>>> isinstance(NA, type)
True
Old style classes are declared deprecated. In Python 3, there are only new-style classes; class A()
is equivalent to class A(object)
and your code will yield True
in both checks.
Take a look at this question for some more discussion: What is the difference between old style and new style classes in Python?
与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…