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