静态方法:
在面向对象三大特性多态中,我们用到了一个类似装饰器的函数
@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'
这样,就实现了删除
属性方法属于三种方法中用的比较多的方法,随着使用会发现它的优点
转载请注明出处
python自学技术互助扣扣群:670402334