1.静态属性:把类的函数属性(method)方法变成像数据属性(field)一样调用。
类属性包括数据属性和函数属性,调用数据属性,直接点,不用括号。调用函数属性,方法名后需要括号。用户在调用的时候并不知道是数据属性还是函数属性,
用户只是想调用,因此需要格式统一,一般在函数属性上一行加@property,使函数属性的调用和数据属性一样。
注意:使用@property后不能传参数,也就是方法只有一个参数self的时候才能使用
classDog:
tag=1
def __init__(self,name,gender):
self.name=name
self.gender=gender
@propertydefeat_(self):print('from eat(self)>>>%s在吃'%self.name)print(Dog.tag) #调用数据属性
dog1=Dog('旺财','公')#dog1.eat_()#不加@property的时候,调用函数属性,需要()
dog1.eat_ #加了@property的时候,调用函数属性,不用()
2.类方法:不用实例化就能调用类的方法
因为类调用方法不进行实例化此时会提示缺少必要的位置参数self。如果参数与self的属性无关还好,如果有关又不实例化肯定报错。毕竟self代表的就是实例本身
classDog:
tag=1
def __init__(self,name,gender):
self.name=name
self.gender=genderdefeat_(self):print('from eat(self)>>>%s在吃'%self.tag)print(Dog.tag) #调用数据属性
Dog.eat_('旺财')
使用@classmethod后
classDog:
tag= 1
def __init__(self, name, gender):
self.name=name
self.gender=gender
@classmethod#使用classmethod后自动传参cls
defeat_(cls):print('from eat(self)>>>%s在吃' %cls.tag)
Dog.eat_()
3.静态方法:名义上的归属类管理,类的工具包, 不能使用类变量和实例变量
如果需要定义.一个与类cls和实例self都无关的方法 ,就需要使用@staticmethod a.没有@staticmethod
classDog:
tag= 1
def __init__(self, name, gender):
self.name=name
self.gender=gender
@classmethod#使用classmethod后自动传参cls
defeat_(cls):print('from eat(self)>>>%s在吃' %cls.tag)deftest(a,b):print('test')
Dog.test(1,2) #可以调用
dog1=Dog('旺财','公')
dog1.test(1,2) #会自动传self,报错
b.加了@staticmethod后,实例不会自动传self,可运行
classDog:
tag= 1
def __init__(self, name, gender):
self.name=name
self.gender=gender
@classmethod#使用classmethod后自动传参cls
defeat_(cls):print('from eat(self)>>>%s在吃' %cls.tag)
@staticmethoddeftest(a, b):print('test')
Dog.test(1, 2) #可以调用
dog1 = Dog('旺财', '公')
dog1.test(1, 2) #会自动传self,报错
注意:静态方法中不能调类属性和方法,也不能调用实例变量,只是类的工具包。因为没有self,也就不能指类本身或实例本身,从而不能调用相应的类属性和类方法。
总结:1.@property跟self绑定,不能传参,参数就是默认的self
2.@ classmethod 跟cls绑定,可以传参
3.@staticmehtod。不跟self和cls绑定,也无法调用类和实例的属性