当给属性赋值的时候,使用实例.属性=属性值
的方式显然把属性暴露出来了,并且也无法对属性值进行限制检查,java中提供了setter和getter方法,那么python是如何做的呢?
在绑定属性时,如果我们直接把属性暴露出去,虽然写起来很简单,但是,没办法检查参数,导致可以把成绩随便改:
s = Student()
= 9999
上面的赋值显然不符合实际情况,为了限制score的范围,可以通过一个set_score()
方法来设置成绩,再通过一个get_score()
来获取成绩,这样,在set_score()
方法里,就可以检查参数:
第一种getter和setter方法:
class Student(object):
def __init__(self,name,score):
= 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())
# ('60')
# print(())
第二种getter和setter方法:
class Student(object):
def __init__(self,name,score):
= name
self.__score = score
@property
def score(self):
return self.__score
@
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)
= 60
print()
总结:
1.第二种方法中,使用了@property装饰器将getter方法变成了属性,而此时@property又创建了另一个装饰器@,负责把setter方法变成属性赋值。这样,就把getter和setter方法装饰成了属性,在调用getter和setter方法的时候就像是在调用该类的属性那样,更直接。但是需要注意的是,此处仍然是方法,只是看起来像属性而已。
2.使用了getter和setter方法后,相比直接调用属性,可以对参数进行必要的检查,如上例中对score进行检查。
3.这里最好写上__init__函数,不然会报"instance attribute defined outside"的警告。