Python 实例方法、类方法、静态方法区别总结
程序员文章站
2022-03-10 19:52:56
实例方法、类方法、静态方法区别总结一、总结1.1 定义形式上:1.2 调用方式上:1.3 使用最多,可以直接处理实例对象的逻辑;二、示例一个代码定义和执行的过程回顾一、总结1.1 定义形式上:类方法和静态方法都是通过装饰器实现的,实例方法不是;实例方法需要传入self参数,类方法需要传入cls参数,而静态方法不需要传self或者cls参数。注意:不管self参数,还是cls参数,都是一种约定俗成的用法,其实是可以使用其他的参数名代替。但是不建议使用其他参数名,毕竟代码不是只是写给自己看的。1...
实例方法、类方法、静态方法区别总结
一、总结
1.1 定义形式上:
- 类方法和静态方法都是通过装饰器实现的,实例方法不是;
- 实例方法需要传入self参数,类方法需要传入cls参数,而静态方法不需要传self或者cls参数。
注意:不管self参数,还是cls参数,都是一种约定俗成的用法,其实是可以使用其他的参数名代替。但是不建议使用其他参数名,毕竟代码不是只是写给自己看的。
1.2 调用方式上:
- 实例方法只能通过实例对象调用;
- 类方法和静态方法可以通过类对象或者实例对象调用;
- 如果是使用实例对象调用的类方法或静态方法,最终都会转而通过类对象调用;
1.3 使用最多,可以直接处理实例对象的逻辑;
- 类方法不需要创建实例对象,直接处理类对象的逻辑;
- 静态方法将与类对象相关的某些逻辑抽离出来,不仅可以用于测试,还能便于代码后期维护。
- 实例方法和类方法,能够改变实例对象或类对象的状态,而静态方法不能。
二、示例
一个代码定义和执行的过程
class A(object):
def m1(self, n):
print("self:", self)
@classmethod
def m2(cls, n):
print("cls:", cls)
@staticmethod
def m3(n):
pass
a = A()
a.m1(1) # self: <__main__.A object at 0x000001E596E41A90>
A.m2(1) # cls: <class '__main__.A'>
A.m3(1)
类中一共定义了3个方法,m1 是实例方法,第一个参数必须是 self(约定俗成的)。m2 是类方法,第一个参数必须是cls(同样是约定俗成),m3 是静态方法,参数根据业务需求定,可有可无。
当程序运行时,大概发生了这么几件事:
- 第一步:代码从第一行开始执行 class 命令,此时会创建一个类 A 对象(没错,类也是对象,一切皆对象嘛)同时初始化类里面的属性和方法,记住,此刻实例对象还没创建出来。
- 第二、三步:接着执行 a=A(),系统自动调用类的构造器,构造出实例对象 a
- 第四步:接着调用 a.m1(1) ,m1 是实例方法,内部会自动把实例对象传递给 self 参数进行绑定,也就是说, self 和 a 指向的都是同一个实例对象。
- 第五步:调用A.m2(1)时,python内部隐式地把类对象传递给 cls 参数,cls 和 A 都指向类对象。
严格意义上来说,左边的都是变量名,是对象的引用,右边才是真正的对像,为了描述方便,我直接把 a 称为对象,你应该明白我说对象其实是它所引用右边的那个真正的对象。
回顾
class A(object):
# 属性默认为类属性(可以给直接被类本身调用)
num = "类属性"
# 实例化方法(必须实例化类之后才能被调用)
def func1(self): # self : 表示实例化类后的地址id
print("func1")
print(self)
# 类方法(不需要实例化类就可以被类本身调用)
@classmethod
def func2(cls): # cls : 表示没用被实例化的类本身
print("func2")
print(cls)
print(cls.num)
cls().func1()
# 不传递传递默认self参数的方法(该方法也是可以直接被类调用的,但是这样做不标准)
@staticmethod
def func3():
print("func3")
print(A.num) # 属性是可以直接用类本身调用的
# A.func1() 这样调用是会报错:因为func1()调用时需要默认传递实例化类后的地址id参数,如果不实例化类是无法调用的
A.func2()
A.func3()
参考:
https://zhuanlan.zhihu.com/p/28010894
https://zhuanlan.zhihu.com/p/40162669
本文地址:https://blog.csdn.net/damanchen/article/details/107646472
上一篇: 对标抖音!微信视频号抢先体验