@staticmethod 与 @classmethod在Python中称为 装饰器,用来修饰函数,相当于添加一个额外的功能,不再像普通函数那样进行实例化。
@staticmethod和@classmethod
其实@staticmethod和@classmethod都是用来声明静态方法的。只不过一个声明静态方法,一个声明类方法。
静态方法:使用装饰器@staticmethod。没有self和cls参数。
类方法:使用装饰器@classmethod。第一个参数为当前类的对象,通常为cls。
为了方便大家了解两者的差别,以下的示例代码将有助于发现其中的差别:
'''
@Author:Runsen
@微信公众号:Python之王
@博客:https://blog.csdn.net/weixin_44510615
@Date:2020/8/30
'''
class A():
# 类的属性
x = 1
@classmethod
def get_name(cls, name):
print(cls.x)
print('my name is %s' % name)
@staticmethod
def get_age(age):
print(A.x)
print(f'i am %s years old' % age)
if __name__ == '__main__':
A.get_name('Runsen')
A.get_age(20)
# 实例对象同样运行
a = A()
a.get_name('Runsen')
a.get_age(20)
#输出如下
1
my name is Runsen
1
i am 20 years old
1
my name is Runsen
1
i am 20 years old
如果在 @staticmethod 中要调用到这个类的一些属性方法,只能直接 类名.属性名或 类名.方法名。而 @classmethod 因为持有cls参数,可以通过cls来调用类的属性,类的方法,实例化对象等,避免硬编码。
@property
@property可以将一个方法的调用变成属性调用。举例说明:平时我们调用数据属性和方法,是这样的
class School():
name = "家里蹲大学"
def test(self):
print("实例方法")
@property
def test_pro(self):
print("静态属性")
if __name__ == "__main__":
s = School()
print(s.name)
s.test()
# 输出如下
家里蹲大学
实例方法
这时就要用到@preperty装饰器,该装饰器能够让一个方法变成属性调用。
class School():
name = "家里蹲大学"
def test(self):
print("实例方法")
@property
def test_pro(self):
print("静态属性")
if __name__ == "__main__":
s = School()
print(s.name)
# 注意返回的函数 千万别加()
s.test_pro
# 输出如下
家里蹲大学
静态属性
从今天以后,在Python编程中,@property广泛应用在Python类的定义中非常常见。你一看到@property,第一反应就是:@property专门负责把一个方法变成同名属性的。
本文已收录 GitHub,传送门~[1] ,里面更有大厂面试完整考点,欢迎 Star。
Reference
[1]传送门~:
https://github.com/MaoliRUNsen/runsenlearnpy100