Python Class 的实例方法/类方法/静态方法

本文详细解释了Python中的实例方法、类方法与静态方法的区别与使用方式,通过实例演示了如何在类中定义并调用这三种方法,并探讨了它们之间的联系与区别。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1. 定义

实例方法、类方法、静态方法

class MyClass(object):

    class_name = "MyClass"  # 类属性, 三种方法都能调用

    def __init__(self):
        self.instance_name = "instance_name"  # 实例属性, 只能被实例方法调用
        self.class_name = "instance_class_name"

    def get_class_name_instancemethod(self):  # 实例方法, 只能通过实例调用
        # 实例方法可以访问类属性、实例属性
        return MyClass.class_name

    @classmethod
    def get_class_name_classmethod(cls):  # 类方法, 可通过类名.方法名直接调用
        # 类方法可以访问类属性,不能访问实例属性
        return cls.class_name

    @staticmethod
    def get_class_name_staticmethod():  # 静态方法, 可通过类名.方法名直接调用
        # 静态方法可以访问类属性,不能访问实例属性
        return MyClass.class_name

    def instance_visit_class_attribute(self):
        # 实例属性与类属性重名时,self.class_name优先访问实例属性
        print "实例属性与类属性重名时,优先访问实例属性"
        print "self.class_name:", self.class_name
        print "MyClass.name:", MyClass.class_name

if __name__ == "__main__":
    MyClass.class_name = "MyClassNew"
    intance_class = MyClass()
    print "instance method:", intance_class.get_class_name_instancemethod()
    print "class method:", MyClass.get_class_name_classmethod()
    print "static method:", MyClass.get_class_name_staticmethod()
    intance_class.instance_visit_class_attribute()

执行效果

instance method: MyClassNew
class method: MyClassNew
static method: MyClassNew
实例属性与类属性重名时,优先访问实例属性
self.class_name: instance_class_name
MyClass.name: MyClassNew

2. 区别

  1. 实例方法

    属于实例的方法
    只能通过实例名.方法名调用。
    其可以访问类属性、实例属性,类方法、实例方法、静态方法。

  2. 类方法

    属于类类的方法
    可以通过实例名.方法名,也可以类名.方法名
    其不能访问实例属性和实例方法

  3. 静态方法

    和类方法很相似,不同的时候定义时要定义(cls)参数
    可以通过实例名.方法名,也可以类名.方法名
    其不能访问实例属性和实例方法

3. 静态方法与类方法

这两者非常像,都是源于C++或JAVA中static的思想。不过我觉得,python的静态方法是从c++和java进化时的一个不完全产物。尽量使用类方法,不使用静态方法。

python的实例属性、类属性对应c++或java中的非静态属性和静态属性
python的实例方法、类方法对应c++或java中的非静态方法和静态方法

下面是一个类方法比静态方法牛逼的地方

class Color(object):
    _color = (0, 0, 0);

    @classmethod
    def value(cls):
        if cls.__name__== 'Red':
            cls._color  = (255, 0, 0)

        elif cls.__name__ == 'Green':
            cls._color = (0, 255, 0)

        return cls._color

    class Red(Color):
        pass

    class Green(Color):
        pass

    class UnknownColor(Color):
        pass

red = Red()
green = Green()
xcolor = UnknownColor()

print 'red = ', red.value()
print 'green = ', green.value()
print 'xcolor =', xcolor.value()
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值