<>静态方法:

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

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

技术
©2020 ioDraw All rights reserved
PTA快速排序SK海力士全球首发DDR5内存:频率冲上5600MHz、容量可达256GB鸿蒙系统基于Linux打造,其本质还是安卓系统?LeetCode快速入门① ——数组系列上(面试常问,建议收藏)特征工程【评论】华为的鸿蒙系统会开源吗?ETL工具kettle与datax的对比测试案例之Oracle to Oraclespark.sql.shuffle.partitions 和 spark.default.parallelism 的区别华为鸿蒙系统能否与安卓、苹果分庭抗礼?centos7部署springboot jar包