我有以下代码:
>>> class MyClass:
pass
>>> myObj=MyClass()
>>> type(myObj)
<type 'instance'> <==== Why it is not type MyClass ?
>>> type(MyClass)
<type 'classobj'> <=== Why it is not just 'MyClass'?
>>> isinstance(myObj, instance) <==== Why the 'instance' is not defined?
Traceback (most recent call last):
File "<pyshell#91>", line 1, in <module>
isinstance(myObj, instance)
NameError: name 'instance' is not defined
>>> isinstance(myObj, MyClass)
True
>>> myObj.__class__
<class __main__.MyClass at 0x0000000002A44D68> <=== Why different from type(myObj) ?
似乎Python在类及其实例类型之间有一些额外的间接。
我习惯了C#。在C#中,typeof(MyClass)
只会返回MyClass
。
以下是2.7.6和3.4.1之间的一些比较。
我想知道如何在Python中实现==
运算符。
答案 0 :(得分:9)
这是因为您正在使用old-style classes。而不是做:
class MyClass:
pass
你需要这样做:
class MyClass(object):
pass
...为了使用新式的课程。现在,如果您执行type(myObj)
,则会按预期返回<class '__main__.MyClass'>
。
事实上,Python引入新式类的主要原因之一正是由于您观察到的问题:
在Python 2.2中引入了新式类来统一类和类型。新式类既不是用户定义的类型,也不是用户定义的类型。如果x是新样式类的实例,则
type(x)
通常与x.__class__
相同(尽管不能保证 - 允许新式类实例覆盖为{返回的值] {1}})。引入新式类的主要动机是提供具有完整元模型的统一对象模型。它还具有许多实际的好处,例如能够对大多数内置类型进行子类化,或者引入“描述符”,它们可以启用计算属性。
(source)
这有点像kludge,不得不扩展x.__class__
,但幸运的是在Python 3中,旧式类被完全删除,因此使用任一种形式声明类都做同样的事情。