本章来讲讲staticmethod,定义静态方法。
定义:静态方法是类中的一种特殊方法,它不需要访问类的实例,也不需要访问实例的属性或方法(独立存在于类中)。静态方法在类的定义中通过@staticmethod装饰器来标记。
特点
1、不需要传递实例参数:静态方法不需要传递类的实例参数(self)或任何实例参数。2、不访问实例属性或方法:静态方法不能访问类的实例属性或方法,因为它与实例无关。
3、通过类名调用:静态方法是通过类名调用的,而不是通过类的实例调用的。
简单示例
class MyClass:
class_variable = "This is a class variable."
def __init__(self, value):
self.instance_variable = value
def instance_method(self):
print(f"This is an instance method. Instance variable: {self.instance_variable}")
@staticmethod
def static_method():
print("This is a static method. It does not require instance or class variables.")
# 创建类的实例
obj = MyClass("Hello")
# 调用实例方法
obj.instance_method()
# 调用静态方法,通过类名调用
MyClass.static_method()
非常简单的用法,没有其他的操作。也没有什么特别的讲究。它与实例方法,其实并无特别的差异。在不同的场景下,适用性不一样,在很多时候,用谁都可以。
示例
class MyClass:
myNmae = "清安"
def name(self):
print(self.myNmae)
return self.myNmae
@staticmethod
def static_method(name):
print(name)
return name
class A1:
# 创建类的实例
obj = MyClass()
class A2:
obj1 = MyClass()
class A3:
obj2 = MyClass()
# 调用实例方法
n = A1().obj.name()
n1 = A2().obj1.name()
n2= A3().obj2.name()
print(n,n1,n2)
这样会打印什么?会打印多少个清安?
结果是会打印6个"清安",为什么?因为实例化导致的。
详细解释:当我们通过A1().obj.name()、A2().obj1.name()和A3().obj2.name()分别调用实例方法时,每次调用都会创建一个新的MyClass的实例。因此,每个实例都会有自己的myNmae属性,并且调用实例方法时会打印出各自实例的属性值。
那么我们改改:
class MyClass:
myNmae = "清安"
def name(self):
print(self.myNmae)
return self.myNmae
@staticmethod
def static_method(name):
print(name)
return name
class A1:
# 创建类的实例
obj = MyClass()
class A2:
obj1 = MyClass()
class A3:
obj2 = MyClass()
name = "清安"
n = A1().obj.static_method(name)
n1 = A2().obj1.static_method(name)
n2= A3().obj2.static_method(name)
那么这样呢?会是什么?这是我自己遇到的一个问题,一个类,实例化调用多次之后,结果就会有多个。那么这样呢?亦或者公用一个实例化,将实例化进行赋值操作。
答案是3个,因为通过A1().obj.static_method(name)、A2().obj1.static_method(name)和A3().obj2.static_method(name)调用静态方法时,并没有创建实例,而是直接调用了静态方法。
关于静态方法
在目前截止,静态方法并没有太多比较逆天的操作,如果有,欢迎大佬指教。
静态方法可以办到的独立定义函数方法一样可以,或者实例化方法也可以OK的,唯一不一样的就是占用内容空间了。大可以将脑洞打开一下,发散一下思维,什么时候适合用静态方法,装逼的时候?什么时候又可以用静态方法。
当你需要在类级别上执行某些操作,而不需要访问实例的状态或属性时,静态方法是合适的。比如:读取文件亦或者新增一些其他方法功能的时候,而又不影响主干的时候。