1.组合

什么是组合?

一个对象的属性是来自另一个类的对象,称之为组合

为什么要用组合

  组合也是用来解决类与类代码冗余的问题

3.如何用组合

# obj1.xxx=obj2
'''
'''
# 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 func2(self):
# print('bar中的功能')
#
# obj1=Foo(10,20)
# obj2=Bar(30,40)
#
# obj1.xxx=obj2 #组合
# print(obj1.x,obj1.y,obj1.aaa,obj1.func1)
# print(obj1.xxx.m,obj1.xxx.n,obj1.xxx.bbb,obj1.xxx.func2) # class OldboyPeople:
# school = 'Oldboy'
# def __init__(self, name, age, gender):
# self.name = name
# self.age = age
# self.gender = gender
#
# class OldboyStudent(OldboyPeople):
# def choose_course(self):
# print('%s is choosing course' %self.name)
#
# class OldboyTeacher(OldboyPeople):
# def __init__(self, name, age, gender,level,salary):
# super(OldboyTeacher, self).__init__(name, age, gender)
# # OldboyPeople.__init__(self, name, age, gender)
# self.level=level
# self.salary=salary
# def score(self,stu,num):
# stu.num=num
# print('老师%s给学生%s打分%s' %(self.name,stu.name,num))
#
# class Course:
# def __init__(self,course_name,course_price,course_period):
# self.course_name=course_name
# self.course_price=course_price
# self.course_period=course_period
# def tell_course(self):
# print('课程名:<%s> 价钱:[%s] 周期:[%s]' % (self.course_name, self.course_price, self.course_period))
#
# python_obj=Course('python开发',3000,'5mons')
# linux_obj=Course('linux运维',5000,'3mons')
#
#
# stu1=OldboyStudent('egon',18,'male')
# stu1.choose_course()
#
# stu1.courses=[]
# stu1.courses.append(python_obj)
# stu1.courses.append(linux_obj)
# stu1.courses[0].tell_course()
#
#
# tea2=OldboyTeacher('kevin',38,'male',5,3000)
# tea2.score(stu1,60) '''
封装
什么是封装?
封装指的是把属性装进一个容器
封 指的是将容器内的属性隐藏你起来,但是这种隐藏是对外不对内的 为何要封装?
封装不是单纯意义的隐藏
封装数据属性的目的:将数据属性封装起来,类外部的使用就无法直接操作改属性了
需要类内部开一个接口给使用者,类的设计者可以再接口之上附加任意逻辑,从而严格控制使用者对属性的操作 封装函数(功能)属性的目的:隔离复杂度,(很多功能是给内部用的,给外部封装起来隔离复杂度) 3.如何封装?
  只需要在属性钱加上__开头,该属性就会被隐藏起来,该隐藏具备的特点:
  1.只是一种语法意义上的变形,即__开头的属性会在检测语法时发生变形,_类名__属性名
  2.这种隐藏式对外不对内的,因为在类内部检测语法时所有的代码都发生了变形
  3.这种变形只在检测语法时发生一次,在类定义之后新增的__开头的属性并不会发生变形
  4.如果父类不想让子类覆盖自己的属性,可以再属性前加__开头
# class Foo:
# __x=111 #_Foo__x
# def __init__(self,m,n):
# self.__m=m # self._Foo__m=m
# self.n=n
#
# def __func(self): #_Foo__func
# print('Foo.func')
#
# def func1(self):
# print(self.__m) #self._Foo__m
# print(self.__x) #self._Foo__x # print(Foo.__dict__)
# Foo.__x
# Foo.__func
# print(Foo._Foo__x)
# print(Foo._Foo__func) obj=Foo(10,20)
# print(obj.__dict__)
# print(obj.n)
# print(obj.__m)
# print(obj._Foo__m) # obj.func1()
# obj._Foo__func() # obj.__yyy=3333 #特点三,
# print(obj.__dict__)
# print(obj.__yyy) # Foo.__zzz=444
# Foo.zzz=333
# print(Foo.__dict__)
# print(Foo.__zzz) # class Foo:
# def __f1(self): #_Foo__f1
# print('Foo.f1')
#
# def f2(self):
# print('Foo.f2')
# self.__f1() #self._Foo__f1
#
# class Bar(Foo):
# def __f1(self): #_Bar__f1
# print('Bar.f1')
#
# obj=Bar()
# obj.f2() # 封装数据属性的真实意图
# class People:
# def __init__(self,name,age):
# self.__name=name
# self.__age=age
# def tell_info(self):
# print('<name:%s age:%s>' %(self.__name,self.__age))
# def set_info(self,new_name,new_age):
# if type(new_name) is not str:
# print('name error')
# return
# self.__name=new_name
# if type(new_age) is not int:
# print('age error')
# return
# self.__age=new_age
# def clear_info(self):
# del self.__name
# del self.__age
#
# obj1=People('aaa',10)
# obj1.tell_info()
# obj1.set_info('aaa',111)
# print(obj1.__dict__)
# obj1.clear_info()
# print(obj1.__dict__) # 封装函数属性的真实意图
# class ATM:
# def __card(self):
# print('插卡')
# def __auth(self):
# print('用户认证')
# def __input(self):
# print('输入取款金额')
# def __print_bill(self):
# print('打印账单')
# def __take_money(self):
# print('取款')
#
# def withdraw(self):
# self.__card()
# self.__auth()
# self.__input()
# self.__print_bill()
# self.__take_money()
#
# a=ATM()
# a.withdraw()
''' # property装饰器:将类中定义的函数(功能)伪装成数据属性
# @property #查看属性的功能
# @xxx.setter #修改属性的功能
# @xxx.deleter #删除属性的功能
# name=property(xxx_name,yyy_name,zzz_name) #古老的做法非装饰下使用这种,(按照括号里的参数名顺序)
'''
例一:BMI指数(bmi是计算而来的,但很明显它听起来像是一个属性而非方法,如果我们将其做成一个属性,更便于理解) 成人的BMI数值:
过轻:低于18.5
正常:18.5-23.9
过重:24-27
肥胖:28-32
非常肥胖, 高于32
  体质指数(BMI)=体重(kg)÷身高^2(m)
  EX:70kg÷(1.75×1.75)=22.86 # class People:
# def __init__(self,name,weight,height):
# self.name=name
# self.weight=weight
# self.height=height
# @property
# def bmi(self):
# print(self.weight/(self.height**2))
#
# obj1=People('aaa',65,1.78)
# obj1.bmi
# obj1.height=1.70
# # obj1.bmi()
# obj1.bmi # 需要了解的property的用法 setter,deleter
# class People:
# def __init__(self,name):
# self.__name=name
# @property
# def name(self):
# return '<name:%s>' %self.__name
# @name.setter
# def name(self,new_name):
# if type(new_name) is not str:
# print('name error')
# return
# self.__name=new_name
# @name.deleter
# def name(self):
# del self.__name
#
# obj=People('egon')
# print(obj.name)
#
# obj.name=123
# print(obj.name)
#
# del obj.name
# print(obj.__dict__) # 常规工作常使用套路
# class People:
# def __init__(self,name):
# self.__name=name
# def xxx_name(self):
# return '<name:%s>' %self.__name
#
# def yyy_name(self,new_name):
# if type(new_name) is not str:
# print('名字必须是str类型')
# return
# self.__name=new_name
# def zzz_name(self):
# del self.__name
#
# name=property(xxx_name,yyy_name,zzz_name)
#
# obj=People('egon')
# print(obj.name)
#
# obj.name=123
# print(obj.name)
#
# del obj.name
# print(obj.__dict__)
'''

多态
1.什么是多态
同一事物的多种形态
在程序中继承可以表现出多态
2.为何要用多态?
多态性:可以再不用考虑对象具体类型(类)的前提下而直接使用对象下的方法
多态的精髓:统一标准
3如何使用多态?
# python崇尚鸭子类型
'''
import abc # class Animal(): # (metaclass=abc.ABCMeta):
# # @abc.abstractmethod
# def speak(self):
# pass # Animal() # 父类只是用来建立规范的,不能用来实例化的,更无需实现内部的方法
# class People(Animal):
# def speak(self):
# print('say hello')
# # def jiao(self):
# # print('say hello')
#
# class Dog(Animal):
# def speak(self):
# print('汪汪汪')
#
# class Pig(Animal):
# def speak(self):
# print('哼哼哼')
#
#
# peo=People()
# dog1=Dog()
# pig1=Pig()
#
#
# peo.speak()
# dog1.speak()
# pig1.speak()
# def speak(animal):
# animal.speak()
#
# speak(peo)
# speak(dog1)
# speak(pig1) # python崇尚鸭子类型
# class Memory:
# def read(self):
# print('mem read')
#
# def write(self):
# print('mem write')
#
# class Disk:
# def read(self):
# print('disk read')
#
# def write(self):
# print('disk write')
#
# class Cpu:
# def read(self):
# print('cpu read')
#
# def write(self):
# print('cpu write')
#
#
# obj1=Memory()
# obj2=Disk()
# obj3=Cpu()
#
# obj1.read()
# obj2.read()
# obj3.read()
#
#
# ''.__len__()
# [].__len__()
# len([1,2,3]) #[1,2,3].__len__()
'''
												

面向对象之 组合 封装 多态 property 装饰器的更多相关文章

  1. PYTHON-组合 封装 多态 property装饰器

    # 组合'''软件重用的重要方式除了继承之外还有另外一种方式,即:组合组合指的是,在一个类中以另外一个类的对象作为数据属性,称为类的组合 1. 什么是组合 一个对象的属性是来自于另外一个类的对象,称之 ...

  2. 面向对象(三)——组合、多态、封装、property装饰器

    组合.多态.封装.property装饰器 一.组合 1.什么是组合 组合指的是某一个对象拥有一个属性,该属性的值是另外一个类的对象 class Foo(): pass class Bar(): pas ...

  3. python面向对象:组合、封装、property装饰器、多态

    一.组合二.封装三.property装饰器四.多态 一.组合 ''' 1. 什么是组合 一个对象的属性是来自于另外一个类的对象,称之为组合 2. 为何用组合 组合也是用来解决类与类代码冗余的问题 3. ...

  4. 组合,多态与多态性,封装以及property装饰器介绍

    一:组合: 什么是组合:组合指的是某一个对象拥有一个属性,该属性的值是另外一个类的对象. 为何要用组合:通过为某一个对象添加属性(属性的值是另外一个类的对象)的方式,可以间接地将两个类关联/整合/组合 ...

  5. python面向编程:类的组合、封装、property装饰器、多态

    一.组合 二.封装 三.propert装饰器 四.多态 一.组合 ''' 1. 什么是组合 一个对象的属性是来自于另外一个类的对象,称之为组合 2. 为何用组合 组合也是用来解决类与类代码冗余的问题 ...

  6. 面向对象(三)--多态、封装、property装饰器

    一.多态与多态性 1.什么是多态 多态指的是同一种类/事物的不同形态 class Animal: def speak(self): pass class People(Animal): def spe ...

  7. 面向对象之封装 及@property装饰器使用

    目录 封装 1.封装的定义 2.封装的目的: 3.封装的三种方式 4.封装的优点 5.访问限制(封装) @property 装饰器 属性property底层实现 封装 1.封装的定义 将复杂的丑陋的, ...

  8. 初识面向对象-封装、property装饰器、staticmathod(静态的方法)、classmethod(类方法) (五)

    封装 # class Room:# def __init__(self,name,length,width):# self.__name = name# self.__length = length# ...

  9. 面向对象之组合、封装、多态、property装饰器

    概要: 组合 封装 property装饰器 多态 Python推崇鸭子类型:解耦合,统一标准(不用继承) 1. 组合 继承:会传递给子类强制属性 组合:解耦合,减少占用内存.如:正常继承,如果一个班级 ...

随机推荐

  1. vue双向绑定(数据劫持+发布者-订阅者模式)

    参考文献:https://www.cnblogs.com/libin-1/p/6893712.html 实现mvvm主要包含两个方面,数据变化更新视图,视图变化更新数据. 关键点在于data如何更新v ...

  2. es6 export 和export default的区别

    区别 export 每个文件中可使用多次export命令 import时需要知道所加载的变量名或函数名 import时需要使用{},或者整体加载方法 export export default 每个文 ...

  3. anaconda3 安装opencv3.4.2 cuda9.2 mint19(ubuntu 18.04)

    从opencv1的时代,编译这玩意就不是太轻松.之前都是在win下.2.x时代,开始用cmake GUI,选vs版本,x86 x64 各种依赖库选项,debug release,... 现在3.4了, ...

  4. (转)Windows上搭建Kafka运行环境

    转自:<Windows上搭建Kafka运行环境> 完整解决方案请参考: Setting Up and Running Apache Kafka on Windows OS   在环境搭建过 ...

  5. 目前用到的一些os.path方法

    这里主要记录下os.path.join()的用法 目录结构如下 在readconfig.py中进行试验,如下 1.使用os.path.realpath(__file__)获取文件所在目录 import ...

  6. Python 编程快速上手 第十八章 用 GUI 自动化控制键盘和鼠标

    前言 这一章节讲述了如何实现 GUI 自动化,首先讲了一些处理异常状况的方法,然后是关于 GUI 自动化的内容,主要有三个部分: 控制鼠标 图像识别 控制键盘 下面引用一段话: 请将 GUI 自动化看 ...

  7. English trip M1 - PC1 Are you a Model? 你是模特吗? Teacher:Taylor

    In this lesson you will learn to talk about jobs. 课上内容(Lesson) What's your partner name? Her name is ...

  8. English trip V1 - 12.Belongings 行李 Teacher:Jade Key: ?

    In this lesson you will learn to describe your home life and things you own. 在本课中,您将学习如何描述您的家庭生活和您拥有 ...

  9. Spring Batch 体系结构

    Spring Batch 设计的时候充分考虑了可扩展性和各类终端用户. 下图显示了 Spring Batch 的架构层次示意图,这种架构层次为终端用户开发者提供了很好的扩展性与易用性. 上图显示的是 ...

  10. Confluence 6 创建一个空间

    在 Confluence 中并不限制你可以创建多少空间.你可以选择为你每一个小组,项目都创建一个空间,或者你也可以将这 2 者混合在一起.所有的这些都基于你的需求来决定的. 每一个 Confluenc ...