python方法的分类(实例方法、类方法、静态方法)

方法和函数的区分

很多童鞋会比较疑惑,方法和函数有什么区别,都是通过def去定义的啊? 
只需要记住一点,方法是用来描述一个目标的行为动作! 
不论你是直接通过 类名.方法调用,还是通过由类生成的实例.方法调用。 
方法都需要有一个目标才能完成调用的操作。

方法分类

谈到python的方法,很多人认为就是一个class 然后跟你的方法名称就完了,哪有什么分类? 
最开始学类的时候我也是这么认为,并且很多的入门书中也没有提及这些。 
那么,到底方法分为哪几类呢? 
让我们先来看一段代码

class MainClass:
    def shilifangfa(self):
        print('这是一个实例方法')    @classmethod
    def leifangfa(cls):
        print('这是一个类方法')    @staticmethod
    def jingtaifangfa():
        print('这是一个静态方法')

m=MainClass()
m.shilifangfa()
m.leifangfa()
m.jingtaifangfa()

output:
这是一个实例方法
这是一个类方法
这是一个静态方法1234567891011121314151617181920

好吧,先说下方法的分类吧: 
1. 实例方法 
2. 类方法 
3. 静态方法

初步展示方法的区别

可是,这三种方法有什么区别呢,光看上面的这段代码,没有任何差异啊。 
那么我们把这段代码稍作修改

class MainClass:
    def shilifangfa(self):
        print('这是一个实例方法',self)    @classmethod
    def leifangfa(cls):
        print('这是一个类方法',cls)    @staticmethod
    def jingtaifangfa():
        print('这是一个静态方法')

m=MainClass()
m.shilifangfa()
m.leifangfa()
m.jingtaifangfa()
output:
这是一个实例方法 <__main__.MainClass object at 0x00000000012AF0B8>
这是一个类方法 <class '__main__.MainClass'>
这是一个静态方法12345678910111213141516171819

这次的输出和上次相比,是否看到实例方法,我们需要传给它一个实例对象,而类方法我们需要传给他的是一个类 
那么如果我们给实例方法传输的不是一个由类产生的实例会如何呢?

MainClass.shilifangfa() 
TypeError: shilifangfa() missing 1 required positional argument: ‘self’

报错的意思很明显,我们需要传给他一个实例的名称,当然你也可以随便写一个数值去传递,那么也就没有作为实例方法的意义了 
说了实例方法,那么类方法呢?同样我们换一种方式去调用

MainClass.leifangfa() 

这是一个类方法

实例方法与类方法的细化区别

这次没有任何变化,为什么呢? 
原因在于,当使用类方法时,传递的参数应该是一个类名,但如果是实例,系统会自动找到实例对应的类名称 
仔细看看下面的代码,你会对实例方法与类方法有更详细的认识

class MainClass:
    a=100 # 方法本身的属性
    def shilifangfa(self):
        print('这是一个实例方法',self.a)
        print(self.index) # 正常访问
        self.a=200 # 相当于实例本身创建了一个属性
        print(self.a) # output a=200
        print(MainClass.a) # output a=100


    @classmethod
    def leifangfa(cls):
        print(cls.index) # type object 'MainClass' has no attribute 'index'
        # 注意这句type object 它变相的告诉你,类也是一个对象,只不过是一个type的对象
        # 这就更验证了python中的那句,万物皆对象
        print('这是一个类方法',cls.a)
        cls.a = 200 # 修改了类本身的a
        print(cls.a)  # output a=200
        print(MainClass.a) # output a=200
        # print(cls.index) # 类方法无法获取到实例的属性
    @staticmethod
    def jingtaifangfa():
        print('这是一个静态方法')

m=MainClass()
m.index=1000 # 实例本身的属性m.shilifangfa()
MainClass.leifangfa()
m.jingtaifangfa()

来源:华为云社区  作者:清风Python

原文地址:https://www.cnblogs.com/2020-zhy-jzoj/p/13165743.html