问题
I'm trying to understand a bit how Python (2.6) deals with class, instances and so on, and at a certain point, I tried this code:
#/usr/bin/python2.6
class Base(object):
default = "default value in base"
def __init__(self):
super(Base, self).__init__()
@classmethod
def showDefaultValue(cls, defl = default):
print "defl == %s" % (defl)
class Descend(Base):
default = "default value in descend"
def __init__(self):
super(Descend, self).__init__()
if __name__ == "__main__":
Descend.showDefaultValue()
The output is: "default value in base"
I was wondering why the "default" field is not overwirtten by the Descend class... Is there any way to overwrite it? Why isn't it being overwritten?
Any hint (or link to an explanatory page will be appreciated). Thank you!
回答1:
The class variable is being overwritten. Try
@classmethod
def showDefaultValue(cls):
print "defl == %s" % (cls.default,)
The reason your way doesn't work has more to do with the way Python treats default arguments to functions than with class attributes. The default value for defl
is evaluated at the time Python defines the binding for showDefaultValue
and this is done exactly once. When you call your method the default value used is what was evaluated at the time of definition.
In your case, defl
was bound to the value of the default
variable as it was during the execution of the class body form of Base
. Regardless of how you call showDefaultValue
later on (i.e., whether via Base
or via Descend
) that value remains fixed in all subsequent invocations of showDefaultValue
.
回答2:
def showDefaultValue(cls, defl=default):
means that default
gets evaluated when the function is defined, as usual in Python. So the definition looks like this then:
def showDefaultValue(cls, defl="default value in base"):
This value of defl
is stored as a default argument on the function object and used when you call the method without arguments. You can look at the defaults of a function like print Descend.showDefaultValue.im_self.default
to validate this.
If you want to get the default from the current class then you have get it from there:
@classmethod
def showDefaultValue(cls, defl=None):
if defl is None:
defl = cls.default
print "defl == %s" % (defl)
来源:https://stackoverflow.com/questions/4763743/overriding-class-variables-in-python