python 类的总结
私有属性
class Dog():
def init(self):
self.heart=100
d=Dog()
d.heart #访问不到,heart属于私有
在变量前加两个下划线,变量变为私有属性,外部不能访问,内部可以访问
def getheart(): return self.heart#提供对外的私有属性的访问方法
对私有属性的强制访问
d.Dogheart- 公有属性(所有类共同拥有的属性)class Dog() type=‘京巴‘ #创建公有属性d=Dog()d2=Dog()Dog.type #这样调用,是在所有类的对象的公有变量里设置d.type#d,d2属性相同 d2.type#当用对象调用的时候,会在自己对象的内存里新建一个type变量
- 析构函数
d=Dog()del d#删除对象名到内存空间的引用 - 继承
静态方法
名义上归类管理,实际上在静态方法里访问不了类或实例中的任何属性
author = ‘Mr.Bool‘
class Dog(object):
def init(self,name):
self.name=name
@staticmethod
def eat():
print("%s like eat 骨头"%self.name)
print(‘狗爱吃骨头‘)
@staticmethod
def eat(self):
print("%s like eat 骨头"%self.name)
# print(‘狗爱吃骨头‘)
def talk(self):
self.eat(self)
print(‘汪汪‘)d=Dog("汪汪")
d.talk()- 类方法@classmethod类方法只能访问类变量。不能访问实例变量。几乎很少用
- 属性方法@property
把一个方法变成一个静态属性,不用括号调用。class Dog(): def init(self): pass @property def eat(self): print(‘狗爱吃骨头‘) @property def eat(self,name): print(‘狗爱吃%s‘%self.name) @eat.setter def eat(self,foot): print(‘set to foot:%s‘%foot) d=Dog() d.eat 调用属性方法 d.eat=‘包子‘ 当属性方法需要传参数,就要重写一个方法,方法名与属性方法名相同 d.Eat=‘包子‘ 大写也可以 当删除属性方法时用 @eat.delete def eat(self): del self.__food print(‘删完了‘) - 类的描述信息
class Dog(): ‘‘‘这个类是描述狗的‘‘‘print(Dog.doc)输出 这个类是描述狗的 - module 和 classmodule输出 这个类是从哪个模块里class输出类
- call对象后面加括号执行calld=Dog()d() 将调用Dog里的call方法
- dict查看对象中的所有成员变量和方法,使用实例调用只打印实例内的属性,不包括类属性
str
在类里写
def str(self): return "<obj:%s>"%self.named直接打印对象就输出str里的内容- getitem,setitem,delitem,把类变成字典
class Foo(object): def init(self): self.data={} pass def getitem(self,key): print(‘getitem‘,key) return self.data.get(key) pass def setitem(self,key,value): print(‘setitem‘,key) self.data[key]=value pass def delitem(self,key): print(‘delitem‘,key) pass obj=Foo() obj[‘name‘]=‘alex‘#自动触发执行 getitem print(obj[‘name‘] #自动触发执行 setitem del obj[‘k1‘] #自动触发执行delitem new metaclass类也是对象,type为类的类
class Dog(): passtype(Dog) 会知道类的类为typenew方法在init构造函数方法前执行new里面调用init
def new(cls,args,*kwargs):print(‘Foo --new--‘)return object.new(cls) 当return被注释时,init不会被调用,这句继承父类的new方法metaclass原类class MyType(): def init(self): print("mytype init") 1 pass def call(self): print("mytype call") 2class Dog(): metaclass=MyType def init(self): print("dog init") 4 pass def new(self): print("dog new") 3
call创建new new创建init反射
getattr setattr hasattr delattrclass Foo(object):def __init__(self):
self.name = ‘wj‘
def func(self):
return ‘func‘obj = Foo()
检查是否含有成员 ####hasattr(obj, ‘name‘)hasattr(obj, ‘func‘)
获取成员 ####getattr(obj, ‘name‘)getattr(obj, ‘func‘)
设置成员 ####setattr(obj, ‘age‘, 18)setattr(obj, ‘show‘, lambda num: num + 1)
删除成员 ####delattr(obj, ‘name‘)delattr(obj, ‘func‘)