Python3.x:静态方法,类方法,属性方法

静态方法:

在面向对象三大特性多态中,我们用到了一个类似装饰器的函数

@staticmethod

其实他就是静态方法,一个装饰器,相当于python内置装饰器,那让我们看看它的作用是什么

class People(object):
    def __init__(self, name):
        self.name = name

    def eat(self, food):
        print('%s is eating %s' %(self.name, food))


man1 = People('James')
man1.eat('chicken')

Python3.x:静态方法,类方法,属性方法_第1张图片
这里定义了一个People类,拥有一个eat函数,可以看到能够正常执行,那让我们给这个eat函数加上这个静态方法看看会怎么样
Python3.x:静态方法,类方法,属性方法_第2张图片
eat()少了一个参数food,这是为什么呢?明明传入了’chicken’
这就是静态方法的作用,把一个类中的函数变为“静态函数”,名义上还是属于类,但是类中的所用方法属性它都调用不了了

eat()少了一个参数food是因为这个时候eat()函数里面的self并不是类中的self了,而是这个函数的一个普通形参,自己传递参数‘chicken’并没有给food而是给了self,所以说eat()少了一个参数food

那我们怎么调用这个静态方法呢?

class People(object):
    def __init__(self, name):
        self.name = name

    @staticmethod
    def eat(food):
        print('James is eating %s' % food)


man1 = People('James')
People.eat('chicken')

虽然静态方法在类中与类没有任何关联了,但是依然属于类,所以我们可以通过类名调用
Python3.x:静态方法,类方法,属性方法_第3张图片
总计一下静态方法:名义上还是归类的,但是访问不了类中的实例变量等其他属性

静态方法@staticmethod用处不多,但是还是需要了解

类方法:

很容易理解,先来说一下类方法的作用

让这个函数只能访问类变量,而不能访问实例变量
Python3.x:静态方法,类方法,属性方法_第4张图片
还是这个例子,也是一个装饰器,使用之后报错People没有属性name,因为这个时候函数eat已经访问不到构造函数里的实例变量了

既然这样,我们就添加个类变量name吧

class People(object):
    name = 'James'

    def __init__(self, name):
        self.name = name

    @classmethod
    def eat(self, food):
        print('%s is eating %s' % (self.name, food))


man1 = People('Jamescxcfyn')
man1.eat('chicken')

这个时候实例化传的参数就用不到了,因为这个函数只会调用类变量
Python3.x:静态方法,类方法,属性方法_第5张图片
可能用到的地方不多,但是还是要了解

属性方法:

把一个函数(方法),变成一个静态属性
Python3.x:静态方法,类方法,属性方法_第6张图片
通过@property可以把下面这个函数变为一个静态属性,这个时候再调用就必须要把函数名后面的括号去掉,因为这个时候它是一个静态属性,否则的话就会报错

可以看到我把第二个参数food去掉了,因为不能像以前一样传参数了,既不能用以前的方法传参,也不不能像给属性赋值一样给它赋值,而是有独特的方法传入参数

class People(object):
    name = 'James'

    def __init__(self, name):
        self.name = name
        self.__food = None

    @property
    def eat(self):
        print('%s is eating %s' % (self.name, self.__food))

    @eat.setter
    def eat(self, food):
        # print('set food to eat', food)
        self.__food = food


man1 = People('James')
# print(man1.__food)
man1.eat = 'chicken'
man1.eat  # James is eating chicken

通过定义一个私有变量,或者普通的变量也可以,这里用私有变量是为了更好的体现属性方法的优点,只提供一个接口操作,代码内容不可见,然后使用@xxx.setter方法来设置这个属性方法中的值

当然,也可以删除,使用@xxx.deleter方法

class People(object):
    name = 'James'

    def __init__(self, name):
        self.name = name
        self.__food = None

    @property
    def eat(self):
        print('%s is eating %s' % (self.name, self.__food))

    @eat.setter
    def eat(self, food):
        # print('set food to eat', food)
        self.__food = food

    @eat.deleter
    def eat(self):
        del self.__food
man1 = People('James')
# print(man1.__food)
man1.eat = 'chicken'
man1.eat  # James is eating chicken
del man1.eat
man1.eat  # AttributeError: 'People' object has no attribute '_People__food'

这样,就实现了删除

属性方法属于三种方法中用的比较多的方法,随着使用会发现它的优点

你可能感兴趣的:(python,大数据,数据库)