面向对象总复习

面向过程编程思想:

​ 核心是过程,过程指的是做事情的步骤,即先干什么再干什么。

​ 基于该编程思想编程,就好比一条流水线,一种机械式的思维方式。

面向对象编程思想:

​ 核心是对象,对象指的是特征与机能的结合体。

​ 基于该编程思想编程,就好比创造世界,一种上帝式的思维方式。

类:

​ 类指的是一系列对象相同的特征与技能的结合体。

如何定义类:

​ 先抽象,抽取对象之间相同的特征与技能。

​ 再定义类。

定义类时会发生哪些事情:

​ 会产生一个类的名称空间

​ 会把类内部的所有名字,扔进该名称空间中

​ 注意:定义类时,就会执行类内部的代码,若语法不正确,则会报错。

如何产生对象:

​ 调用类会产生一个对象,调用类的过程称之为类的实例化,对象称之为类的一个实例化。

​ --init--:调用类时触发该方法。

调用类时发生的事情:

​ 调用类会产生一个对象的名称空间。

​ 会触发--init--,接着把对象与括号内所有的参数都传给--init--(),把对象当作第一个参数。

​ 在--init--内部,可以给对象添加属性。

对象的名字查找:

​ 先找对象自己的

​ 若对象没有,则去类中查找

​ 类中没有,则会默认继承object类中查找

对象的绑定方法特殊之处:

​ 类来调用,类内部的方法只是一个普通的函数,函数需要几个参数就传几个。

​ 对象的绑定方法,由对象来调用,会自动把对象当作第一个参数传给该方法。

​ 注意:不同对象调用对象的绑定方法,会绑定给不同的对象

一切皆对象:

​ 在python中一切皆对象。

​ python八大数据类型皆为对象:

​ n =10 #n = int(10)

​ list truple set dict float bool str int

​ 内置函数:filter

继承:

​ 继承指的是新建类的方式,新建的类指的子类或派生类。

​ 子类可以继承一个父类,父类又可以称之为基类或超类。

如何查找继承关系:

​ 必须遵循“先抽象,再继承”

抽象:

​ 抽取相似的部分

​ --先抽象

​ 抽取相似的部分。

​ --再继承

​ 确认好之类与父类

​ 定义父类,父类中写类与类之间相同的特征与技能。

​ 子类继承与父类的属性

class Father:

​ pass

class Sub(Father):

​ pass

继承关系:

​ 类是对象与对象之间的关系,类是一系列对象相同的特征与技能的结合体。

​ 继承是类与类之间的关系,子类与父类是一种从属关系。

派生:

​ 派生值的子类继承父类的属性,并派生出自己的属性。

子类可以派生出自己的属性,并重用父类的属性。

​ 直接调用类,类名.属性的方式重用父类的属性。

​ super(),super().指的是父类的名称空间,重用父类的属 性。

​ 注意:子类派生出与父类相同的属性,以子类的为主。

在继承背景下,对象属性的查找顺序

​ 先从对象的名称空间中查找

​ 去类的名称空间中查找

​ 去父类的名称空间中查找

​ 去object里面查找,若没有则报错。

新式类与经典类:

​ 继承object的类,都称之为新式类。

​ 在python2中,没有继承object的类,都称之为经典类。

砖石继承:

​ 新式类:

​ 广度优先

​ 经典类:

​ 深度优先

组合:

​ 组合指的是一个对象的属性,是另一个对象。

​ 组合的作用,与继承一样,都是解决代码冗余问题。

​ 继承的有点:

​ 编写代码的复杂程度没有组合高。

​ 继承的缺点:

​ 耦合度太高,可扩展性差。

​ 组合的优点:

​ 可以让类与类之间解耦合,可扩展性高。

​ 组合的缺点:

​ 编写的复杂程度高于继承

封装:

​ 封装指的是把一堆属性,封装到对象中,对象就好比一个袋子,或是一个容器。

​ 优点:

​ 方便数据的存取

​ 可以通过“对象.属性”的方式获取与方法。

​ 封装是面向对象的核心

访问机制:

​ 在类内部,凡事以——开头的属性,都会被隐藏,不轻易被直接调用,保证数据安全。

​ 比如与金钱,用户信息相关的操作

property:

​ 让看起来像动词的方法,变成一名词的方式调用。

​ 方法名 不需要加括号调用。

多态:

​ 同一样事物的多种形态。

​ 水:液态水,固态水,气态水

​ 多态的目的

​ 为了统一代码编写规范。

​ 多态的实现方式:

​ 继承:

​ 子类继承父类的特征与技能。

​ 抽象类:

​ 导入一个abc模块

​ 让父类继承一个ABCMeta

​ 给类内部所有的方法加上abc.abcstracmethod装饰器,子类继承抽象类,强制让子类继承父类的方法,缺一不可。

​ 鸭子类型

​ 只要长得像鸭子,你就是鸭子了

class method:

​ 是一个装饰器,用来装饰在类内部的方法,可以让该方法变成类的绑定方法。

​ 对象绑定方法:

​ 由对象来调用,会把对象当作第一个参数传给该方法

​ 类的绑定方法:

​ 由类来调用,会把类当作第一个参数传给该方法。

staticmethod:

​ 是一个装饰器,用来装饰在类内部的方法,可以让该方法变成非绑定方法。

​ 非绑定方法特殊之处:

​ 由谁来调用都是一个普通该函数。

面向对象高级:

​ isintance:

​ 判断对象是否是一个类的实例

​ issubclass:

​ 判断一个类是否是另一个类的子类。

​ 反射:

​ 通过字符串操作对象或类的属性。

​ hasattr:判断字符串是否是一个对象的属性

​ getattr:通过字符串,获取一个对象或类的属性,若没有默认是none。(‘对象或类’,‘字符串属性名’,‘自定义的默认值’)

​ setattr:通过字符串,设置一个对象或类的属性。(‘对象或类’,‘字符串属性名’,‘属性的值’)

​ delattr:通过字符串,删除一个对象或类的属性。(’对象或类‘,’删除的字符串属性名‘)

魔法方法(类的内置方法):

​ --Init--:在调用类时触发,在--new--没有返回一个空对象时不会触发。

​ --new--:在--init--执行前触发,必须要返回一个空对象。(-object.--new--(cls) #cls-->当前类)

​ --str--:在打印对象时触发。

​ --getattr--:会在对象.属性,不管属性有没有都会触发。

加分项(面试会问):

​ --setattr--:会在对象.属性=属性值时触发。

​ --del--:会在对象被销毁前触发。

​ --call--:会调用对象时执行。

​ --delattr--:会在对象删除属性时触发。

单例模式:

​ 单例模式指的是,调用一个类时实例化得到多个对象时,对象指向同一个名称空间。

​ --@classmethod

​ --new--

day 23的更多相关文章

  1. Java开发中的23种设计模式详解

    [放弃了原文访问者模式的Demo,自己写了一个新使用场景的Demo,加上了自己的理解] [源码地址:https://github.com/leon66666/DesignPattern] 一.设计模式 ...

  2. ILJMALL project过程中遇到Fragment嵌套问题:IllegalArgumentException: Binary XML file line #23: Duplicate id

    出现场景:当点击"分类"再返回"首页"时,发生error退出   BUG描述:Caused by: java.lang.IllegalArgumentExcep ...

  3. CSharpGL(23)用ComputeShader实现一个简单的ParticleSimulator

    CSharpGL(23)用ComputeShader实现一个简单的ParticleSimulator 我还没有用过Compute Shader,所以现在把红宝书里的例子拿来了,加入CSharpGL中. ...

  4. ABP(现代ASP.NET样板开发框架)系列之23、ABP展现层——异常处理

    点这里进入ABP系列文章总目录 基于DDD的现代ASP.NET开发框架--ABP系列之23.ABP展现层——异常处理 ABP是“ASP.NET Boilerplate Project (ASP.NET ...

  5. Java开发中的23种设计模式详解(转)

    设计模式(Design Patterns) ——可复用面向对象软件的基础 设计模式(Design pattern)是一套被反复使用.多数人知晓的.经过分类编目的.代码设计经验的总结.使用设计模式是为了 ...

  6. C#得到某月最后一天晚上23:59:59和某月第一天00:00:00

    项目需求: 某学校订单截止操作时间的上一个月最后一天晚上23:59:59 为止所有支付的订单统计: 代码: /// <summary> /// 通过学校和截止时间得到订单 /// < ...

  7. C#开发微信门户及应用(23)-微信小店商品管理接口的封装和测试

    在上篇<C#开发微信门户及应用(22)-微信小店的开发和使用>里面介绍了一些微信小店的基础知识,以及对应的对象模型,本篇继续微信小店的主题,介绍其中API接口的封装和测试使用.微信小店的相 ...

  8. [转载]IIS7报500.23错误的解决方法

    原文出处: 原文作者:pizibaidu 原文链接:http://pizibaidu.blog.51cto.com/1361909/1794446 背景:今天公司终端上有一个功能打开异常,报500错误 ...

  9. [MySQL Reference Manual] 23 Performance Schema结构

    23 MySQL Performance Schema 23 MySQL Performance Schema 23.1 性能框架快速启动 23.2 性能框架配置 23.2.1 性能框架编译时配置 2 ...

  10. Error:failed to find Build Tools revision 23.0.0 rc3

    解决,选择AS里有的版本就可以了,已有的我这就一个23.0.3,导入的项目是23.0.2 Donate:)

随机推荐

  1. 虚IP解决AlWaysON读库服务器过保替换

    公司核心交易数据库,使用SQL 2012 AlWaysON的1主4从,有2台(8.14,8.15)从库服务器,已经使用3年多,过保替换,新买的2台服务器已经安装好,一开始方案如下: 服务器(8.14) ...

  2. 爬虫基本知识之C/S交互

    概念 爬虫就是对网页的获取. 一般获取的网页中又有通向其他网页的通路,我们叫做超链接,那么就可以通过这样的通路获取更多其他的网页,就像一只在网路上爬行的蜘蛛,所以俗称爬虫. 爬虫的工作原理和浏览器浏览 ...

  3. JS数组方法整理(附使用示例)

    整理目前所用过的数组方法,学习了新增的es6方法. 1.arr.push() 从后面添加元素,返回值为添加完后的数组的长度 let arr = [1,2, is 8.3,4,5] console.lo ...

  4. C# 表达式树遍历(二)

    一.前言 上一篇我们对表达式树有了初步的认识,这里我们将对表达式树进行遍历,只有弄清楚了他的运行原理,我们才可以对他进行定制化修改. 表达式系列目录 C# 表达式树讲解(一) C# 表达式树遍历(二) ...

  5. Netty源码分析 (八)----- write过程 源码分析

    上一篇文章主要讲了netty的read过程,本文主要分析一下write和writeAndFlush. 主要内容 本文分以下几个部分阐述一个java对象最后是如何转变成字节流,写到socket缓冲区中去 ...

  6. 爬取凤凰网站财经类的新闻,函数时编程,可全部实现,由于内容量大,需要时间太长,服务器会禁止,为了防止,可以将time.sleep()设置的时间长点

    import requests from selenium import webdriver import time def grasp(urlT): driver = webdriver.Chrom ...

  7. scrapy-redis分布式爬取猫眼电影

    能够利用redis缓存数据库的优点去重来避免数据的大面积冗余 1.首先就是要创建猫眼爬虫项目 2.进入项目内部创建一个爬虫文件 创建完文件之后就是要爬取的内容,我这边以爬取猫眼电影的title和lin ...

  8. helm在kubernetes环境中搭建

    1.安装helm 1.1.安装helm客户端 各个版本的helm:https://github.com/helm/helm/releases wget https://get.helm.sh/helm ...

  9. Sqoop介绍、安装与操作

    搭建环境 部署节点操作系统为CentOS,防火墙和SElinux禁用,创建了一个shiyanlou用户并在系统根目录下创建/app目录,用于存放 Hadoop等组件运行包.因为该目录用于安装hadoo ...

  10. Python连载38-协程、可迭代、迭代器、生产者消费者模型

    一.生产者消费者模型 import multiprocessing from time import ctime def consumer(input_q): print("Into con ...