看下面一串代码:
class MyCls(object):
__age = 20
def __init__(self):
self.__age = 18
def a(self):
return self.__age
@classmethod
def b(cls):
return cls.__age
@staticmethod
def c():
return MyCls.__age # 这里没参数传入,必须通过类对象访问
@classmethod
def update(cls,age):
cls.__age = age
test = MyCls()
# 普通方法
print(test.a())
# 类方法可以通过实例对象和类对象去调用
print(test.b())
print(MyCls.b())
# 静态方法可以通过实例对象和类对象去调用
print(test.c())
print(MyCls.c())
# 类方法修改类属性
test.update(100)
print(test.b())
print(MyCls.b())
总结:1、实例方法需要通过实例对象去调用,静态方法和类方法实例对象和类对象都可以调用。
2、实例方法第一个参数是self,类方法第一个参数是cls,静态方法不需要额外的参数。
3、当__init__中定义的实例属性与类属性冲突时,实例方法调用的结果是实例属性,静态方法和类方法调用的是类属性。
4、类方法还有一个作用就是可以对类属性进行修改。
拓展:上面几种方法都可以调用私有属性?那还有没有其他更好的方法呢?这时@property登场了
class MyCls(object):
__age = 20
@property
def age(self):
return self.__age
test = MyCls()
print(test.age)
看这段代码你可能会疑问,诶,这跟上面没什么区别啊,仔细看看test.age,是不是发现少了个括号,难道我写错了吗?其实@property的效果就是让test以访问属性的方式去访问age方法。 在这里你可能觉得@property并没有简洁多少啊,大家可以参考下文,就会发现@property好处了https://blog.youkuaiyun.com/u013205877/article/details/77804137