<>静态方法:

在面向对象三大特性多态中,我们用到了一个类似装饰器的函数
@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')

这里定义了一个People类,拥有一个eat函数,可以看到能够正常执行,那让我们给这个eat函数加上这个静态方法看看会怎么样

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')
虽然静态方法在类中与类没有任何关联了,但是依然属于类,所以我们可以通过类名调用

总计一下静态方法:名义上还是归类的,但是访问不了类中的实例变量等其他属性

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

<>类方法:

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

让这个函数只能访问类变量,而不能访问实例变量

还是这个例子,也是一个装饰器,使用之后报错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')
这个时候实例化传的参数就用不到了,因为这个函数只会调用类变量

可能用到的地方不多,但是还是要了解

<>属性方法:

把一个函数(方法),变成一个静态属性

通过@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'
这样,就实现了删除

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

技术
今日推荐
下载桌面版
GitHub
百度网盘(提取码:draw)
Gitee
云服务器优惠
阿里云优惠券
腾讯云优惠券
华为云优惠券
站点信息
问题反馈
邮箱:[email protected]
QQ群:766591547
关注微信