python中两种getter和setter方法

当给属性赋值的时候,使用实例.属性=属性值的方式显然把属性暴露出来了,并且也无法对属性值进行限制检查,java中提供了setter和getter方法,那么python是如何做的呢?

在绑定属性时,如果我们直接把属性暴露出去,虽然写起来很简单,但是,没办法检查参数,导致可以把成绩随便改:

s = Student()
s.score = 9999

上面的赋值显然不符合实际情况,为了限制score的范围,可以通过一个set_score()方法来设置成绩,再通过一个get_score()来获取成绩,这样,在set_score()方法里,就可以检查参数:

第一种getter和setter方法:

class Student(object):
    def __init__(self,name,score):
        self.name = name
        self.__score = score
    def get_score(self):
        return self.__score
    def set_score(self,score):
        if not isinstance(score,int):
            raise ValueError('score must be an Integer')
        if score < 0 or score > 100:
            raise ValueError('score must between 0 ~ 100!')
        self.__score = score
s = Student('张三',59)
s.set_score(60)
print(s.get_score())
# s.set_score(9999)
# print(s.get_score())
# s.setScore('60')
# print(s.getScore())



第二种getter和setter方法:

class Student(object):
    def __init__(self,name,score):
        self.name = name
        self.__score = score
    @property
    def score(self):
        return self.__score
    @score.setter
    def score(self,score):
        if not isinstance(score,int):
            raise ValueError('score must be a Integer')
        if score < 0 or score > 100:
            raise ValueError('score must between 0~100!!!')
        self.__score = score
s = Student('张三',59)
s.score = 60
print(s.score)

总结:

1.第二种方法中,使用了@property装饰器将getter方法变成了属性,而此时@property又创建了另一个装饰器@score.setter,负责把setter方法变成属性赋值。这样,就把getter和setter方法装饰成了属性,在调用getter和setter方法的时候就像是在调用该类的属性那样,更直接。但是需要注意的是,此处仍然是方法,只是看起来像属性而已。

2.使用了getter和setter方法后,相比直接调用属性,可以对参数进行必要的检查,如上例中对score进行检查。

3.这里最好写上__init__函数,不然会报"instance attribute defined outside"的警告。

你可能感兴趣的:(python)