封装:隐藏属性或方法,外部没法使用,内部可使用,在类定义阶段就执行了,真的想引用,就使用_类名__属性名
#好比 class YwY: __name = 1 #其等同于作了这一层处理_YwY__name = 1 a = YwY() print(a.__name) #会报错,类外面无法直接引用类里面隐藏的变量 #咱们若是直接用类来引用这个变量 #全部咱们真的要拿里面的变量的话 prnt(a._YwY__name) # 隐藏模块内的函数/变量_x:from module import *(没法导入), from module import _x(不合理) 如 class YwY: def __func():#其等同于作了这一层处理def _YwY__func() pass #封装后咱们要在类内部使用封装后的变量或者变量名,咱们能够直接导入他的变量名或者函数名便可 class YwY: __name = 1 def __one(self): print('1') def __two(self): print('1') def func(self): print(self.__name) self.__one() self.__two() a = YwY() a.func()
# @property:被 @property 装饰的函数会从函数变成属性,也就是说直接.函数名,不须要加括号使用 #以下 class Func: @property def a(self): print('1') a = Func() a.a #1
# @方法名.setter:被 @方法名.setter 装饰的函数装饰函数名字必须和方法名字相同,方法名修改,会执行这个装饰的函数, #coding=utf-8 # ############### 定义 ############### class Goods: """python3中默认继承object类 以python二、3执行此程序的结果不一样,由于只有在python3中才有@xxx.setter @xxx.deleter """ @property #方法必须先进行@property def price(self): print('@property') @price.setter def price(self, value): #函数名必须和方法相同 print('@price.setter') @price.deleter def price(self): print('@price.deleter') # ############### 调用 ############### obj = Goods() obj.price # 自动执行 @property 修饰的 price 方法,并获取方法的返回值 obj.price = 123 # 自动执行 @price.setter 修饰的 price 方法,并将 123 赋值给方法的参数 del obj.price # 自动执行 @price.deleter 修饰的 price 方法
因为新式类中具备三种访问方式,咱们能够根据它们几个属性的访问特色,分别将三个方法定义为对同一个属性:获取、修改、删除python
# 对象的绑定方法:没有加任何装饰的方法就是对象的绑定方法 # 类的绑定方法:加了@classmethod装饰器的方法就是类的绑定方法,里面的形参必须是cls而不是self,约定俗称 # 非绑定方法:加了@staticmethod装饰器的方法就是非绑定方法,其实就是一个普通的函数,里面的self没有意义
经典类是深度优先函数
新式类是广度优先code