一.封装 把一堆东西装在一个容器里 函数和属性装到了一个非全局的命名空间 class A: __N = 123 # 静态变量 def func(self): print(A.__N) # 在类的内部使用正常 a=A()a.func()print(A.__N) # 在类的外部直接使用 报错 print(A._A__N) # python就是把__名字当成私有的语法 定义一个私有的名字 : 就是在私有的名气前面加两条下划线 __N =123所谓私有,就是不能在类的外面去引用它 一个私有的名字 在存储…
一.封装 封装 : 广义上的 :把一堆东西装在一个容器里 狭义上的 :会对一种现象起一个专门属于它的名字 函数和属性装到了一个非全局的命名空间 —— 封装 隐藏对象的属性和实现细节,仅对外提供公共访问方式. [好处] 1. 将变化隔离: 2. 便于使用: 3. 提高复用性: 4. 提高安全性: [封装原则] 1. 将不需要对外提供的内容都隐藏起来: 2. 把属性都隐藏,提供公共方法对其访问. 私有变量和私有方法 在python中用双下划线开头的方式将属性隐藏起来(设置成私有的) class A:…
组合 什么有什么的关系 一个类的对象作为另一个类的对象继承 子类可以使用父类中的名字(静态属性 方法)抽象类和接口类 只能不继承,不能被实例化 子类必须实现父类中的同名方法———规范代码 metaclass=ABCMeta @abstractmethod python 支持多继承,对于python 来说,抽象类和接口类没有区别 接口类是python 特有的,因为Pythonz直接用类就可以实现接口的效果 python没有'接口'这种数据类型,java中有 继承多态封装propertyclassm…
目录 类的封装 类的property特性 类与对象的绑定方法与非绑定方法 类的封装 封装: 就是打包,封起来,装起来,把你丢进袋子里,然后用绳子把袋子绑紧,你还能拿到袋子里的那个人吗? 1.隐藏属性和方法,外部(类的外部)无法使用,内部(类额内部)可以使用,在类定义阶段就执行了,真的想引用,就使用_类名__属性名 封装分为两个层面: 第一个层面: 对象能拿到类的东西,但是类能拿到对象的东西吗? class Foo(): count = 0 print(count) f = Foo() print…
组合的应用: 1. 什么是组合 一个对象的属性是来自于另外一个类的对象,称之为组合 2. 为何用组合 组合也是用来解决类与类代码冗余的问题 3. 如何用组合 '''class Foo: aaa=1111 def __init__(self,x,y): self.x=x self.y=y def func1(self): print('Foo内的功能') class Bar: bbb=2222 def __init__(self, m, n): self.m = m self.n = n def…
封装 封装:主要是指在类的定义阶段将,以__开头的属性名进行变形..例如:__name ==> _People__name 封装的主要特点: 1.在类外部无法直接__name,想要在外部调用可以使用_People__name 2.在类内部可以直接使用__name 3.子类无法覆盖父类__开头的属性 解释特点3的例子: class Foo: def __func(self): # _Foo_func print('from foo') class Bar(Foo): def __func(self…
一.课前内容回顾 继承作用:提高代码的重用性(要继承父类的子类都实现相同的方法:抽象类.接口) 继承解释:当你开始编写两个类的时候,出现了重复的代码,通过继承来简化代码,把重复的代码放在父类中. 单继承: 重用性:减少代码的重复,子类可以复用父类的方法 派生:子类在父类的基础上又创建了自己的新的方法和属性 子类中有父类的同名方法:只用子类的 还希望用到父类中的方法:父类名(self,...).super(...)调用 抽象类:只能被继承,不能被实例化 模板.规则 抽象类的模板: from abc…
1.基本概念 在python中用双下划线开头的方式将属性隐藏起来(设置成私有的) #其实这仅仅这是一种变形操作 #类中所有双下划线开头的名称如__x都会自动变形成:_类名__x的形式: class A: __N=0 #类的数据属性就应该是共享的,但是语法上是可以把类的数据属性设置成私有的如__N,会变形为_A__N def __init__(self): self.__X=10 #变形为self._A__X def __foo(self): #变形为_A__foo print('from A')…
面向对象 - 封装: 封装:在类定义阶段,以__开头的属性名发生了变形 eg: __x --> _A__x / __foo --> _A__foo 1.特点: 1.在类外部无法直接访问 __x 是 _A__x 2.在类内部可以直接使用 self.__foo() == self._A__foo() 3.子类无法覆盖父类以__开头的属性 因为根本不是一个名字 __x _A__x 2.总结: 这种变形需要注意的问题: 1.这种机制也并没有真正意义上限制我们从外部直接访问属性,知道了类名和属性名就可以…
@property 废话少说,贴上代码(代码参考@廖雪峰教程) class Student(object): def __init__(self, score): self._score = score @property def score(self): return self._score @score.setter def score(self, value): '''这里对score进行判断.处理的操作''' self._score = value 通过这样的处理,实例对象self._s…