我有两个非常基本的面向对象的问题

1)我们可以用成员函数修改类变量吗?

例如

class test:
    '''test class'''

    idd=0
    def __init__(self,mark,subject):

        self.markk=mark
        self.subjectt=subject

    def display(self):
        print "the display is",self.markk,self.subjectt;
stud1=test(30,'maths')
stud2=test(40,'english')


当我尝试使用对象stud1.idd = 9;修改类变量idd时,该变量未修改。 test.idd = 9修改了变量。

有人可以解释一下为什么无法从对象修改类变量吗?

2)同样在上述代码段中,当我添加了一个带有var idd之类的关键字global时

class test:
    '''test class'''
    global idd;
   idd=0;
print test.idd


它抛出了错误,例如名称类测试没有属性idd。

但是当我注释掉全局idd时,它显示了价值。

那么类中不支持全局关键字吗?

有人可以帮助我对这两个问题有所了解,因为这是我迈向面向对象概念的基本步骤。

最佳答案

我认为您不了解python通过查看object1的“链”来查找值。当您执行value = self.foo时,python将首先在实例上查找foo。然后它将在类上显示。然后,它将查看超类(按其“方法解析顺序”)。

当你写:

self.foo = 'bar'


Python只是将foo放在实例上。因此,即使对该类也定义了'bar',现在在该实例上进行的后续查找也将为您提供foo。还要注意,由于foo放在实例上,因此在类上看不到任何更改。

如果要以特定方法更新类,则可以使用classmethod

class Foo(object):
    idd = 0
    @classmethod
    def increment_idd(cls):
        cls.idd += 1

f = Foo()
f.increment_idd()
print(Foo.idd)
print(f.idd)


但是,如果您需要访问self,则此方法不起作用。在这种情况下,您需要从实例获取对该类的引用:

class Foo(object):
    idd = 0
    def increment_idd(self):
        cls = type(self)
        cls.idd += 1

f = Foo()
f.increment_idd()
print(Foo.idd)
print(f.idd)


1如果您知道javascript,实际上与javascript的原型继承没有太大不同

10-08 15:19