​ Python中的@staticmethod方法总结一句话:不实例化类的情况下直接使用该方法

  1. 不需要约定的默认参数self。
  2. 静态方法就是类对外部函数的封装,有助于优化代码结构和提高程序的可读性。
class Person:
def __init__(self,name):
self.name=name
print('调用者')
def _name(self):
print(self.name)
@staticmethod
def static_method():
print('调用静态方法!')

if __name__ == '__main__':
person = Person("buji")
print("------这是name方法------")
person._name()

print("------这里调用静态方法------")
person.static_method()
'''
打印结果:

调用者
------这是name方法------
buji
------这里调用静态方法------
调用静态方法!
'''

​ 解析:
1)正常我们使用类去实例化对象时会先走 init方法给对象进行初始化赋值。
2)但是使用了staticmethod静态方法后可以直接使用 (类.对象或者类的实例.对象) 去调用被静态方法装饰后的函数,这个过程是不会走init这个方法的,简言之就是不会给对象进行赋值初始化
3)上面代码执行的结果也表明了这一点,调用_name方法时打印出了init方法里面的”调用者”,而调用static_method()时并没有打印出“调用者”
4)怎么解释这句 静态方法有助于优化代码结构和提高程序的可读性,把某些应该属于某个类的函数给放到那个类里去。解:可以把被静态方法装饰的函数放在类的外面,这样在类里面可以调用该函数,但是这样对代码的结构以及可读性不太友好。