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

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

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. 其可以访问类属性、实例属性,类方法、实例方法、静态方法。
  • 类方法

    1. 属于类类的方法
    2. 可以通过实例名.方法名,也可以类名.方法名
      3.其不能访问实例属性和实例方法
  • 静态方法

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

3.静态方法与类方法

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

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

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

'''
遇到问题没人解答?小编创建了一个Python学习交流QQ群:857662006 寻找有志同道合的小伙伴,
互帮互助,群里还有不错的视频学习教程和PDF电子书!
'''
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、付费专栏及课程。

余额充值