Python全栈开发记录_第九篇(类的基础_封装_继承_多态)

  有点时间没更新博客了,今天就开始学习类了,今天主要是类的基础篇,我们知道面向对象的三大特性,那就是封装,继承和多态。内容参考该博客https://www.cnblogs.com/wupeiqi/p/4493506.html

  之前我们写的都是函数,可以说是面向过程的编程,需要啥功能就直接写啥,但是我们在编写程序的过程中会发现如果多个函数有共同的参数或数据时,我们也必须多次重复去写,此时如果用面向对象的编程方式就会好很多,这也是面向对象的适用场景。

面向对象三大特性:

一、封装(顾名思义就是将内容封装到某个地方,以后再去调用被封装在某处的内容,具体看下面的代码)

#!/usr/bin/env python
# -*- coding:utf-8 -*-
# Author: Xiaobai Lei

class Person:
    def __init__(self, name, age):
        self.name = name
        self.age = age

    def get_msg(self):
        print(self.name)
        print(self.age)

p1 = Person(‘xiaobai‘, 18)
p1.get_msg()    # Python默认会将p1传给self参数,即:p1.get_msg(p1),所以,此时方法内部的 self = p1

p2 = Person(‘xiaoming‘, 88)
p2.get_msg()    # 此处一样将p2传给self参数

# 对于面向对象的封装来说,其实就是使用构造方法将内容封装到对象中,然后通过对象直接或者self间接获取被封装的内容。

二、继承(通俗来说就是继承父类的所有东西,与现实一致)

# 2、继承
class Person:
    def __init__(self, name, age):
        self.name = name
        self.age = age

    def eat(self):
        print("%s在吃饭" %self.name)

# 在类后面括号中写入另外一个类名,表示当前类继承另外一个类
class Teacher(Person):
    def teacher(self):
        print("%s在教书" %self.name)

t1 = Teacher("小白", 18)
t1.eat()
t1.teacher()

# 对于面向对象的继承来说,其实就是将多个类共有的方法提取到父类中,子类仅需继承父类而不必一一实现每个方法。

  除了上面的单继承以外还有多继承,ython的类如果继承了多个类,那么其寻找方法的方式有两种,分别是:深度优先广度优先,详情往下看:

  

  • 当类是经典类时,多继承情况下,会按照深度优先方式查找
  • 当类是新式类时,多继承情况下,会按照广度优先方式查找

经典类和新式类,从字面上可以看出一个老一个新,新的必然包含了跟多的功能,也是之后推荐的写法,从写法上区分的话,如果 当前类或者父类继承了object类,那么该类便是新式类,否则便是经典类。

   

经典类多继承如下:
class D:

    def bar(self):
        print(‘D.bar‘)

class C(D):

    def bar(self):
        print(‘C.bar‘)

class B(D):

    def bar(self):
        print(‘B.bar‘)

class A(B, C):

    def bar(self):
        print(‘A.bar‘)

a = A()
# 执行bar方法时
# 首先去A类中查找,如果A类中没有,则继续去B类中找,如果B类中么有,则继续去D类中找,如果D类中么有,则继续去C类中找,如果还是未找到,则报错
# 所以,查找顺序:A --> B --> D --> C
# 在上述查找bar方法的过程中,一旦找到,则寻找过程立即中断,便不会再继续找了
a.bar()

# 对于同一个根需要注意
class D:

    def bar1(self):
        print(‘D.bar‘)

class C(D):

    def bar1(self):
        print(‘C.bar‘)

class B(D):

    def bar(self):
        print(‘B.bar‘)

class A(B, C):

    def bar(self):
        print(‘A.bar‘)

a = A()
# 执行bar1方法时
# 首先去A类中查找,如果A类中没有,则继续去B类中找,如果B类中没有,按理说应该去D类中找了,但是D类是B和C的同一个根类,所以先不找,先找C,C找不到才会最后找D这个共同的根类
# 所以,查找顺序:A --> B --> C --> D
# 在上述查找bar1方法的过程中,一旦找到,则寻找过程立即中断,便不会再继续找了
a.bar1()
新式类多继承如下:
class D(object):

    def bar(self):
        print(‘D.bar‘)

class C(D):

    def bar(self):
        print(‘C.bar‘)

class B(D):

    def bar(self):
        print(‘B.bar‘)

class A(B, C):

    def bar(self):
        print(‘A.bar‘)

a = A()
# 执行bar方法时
# 首先去A类中查找,如果A类中没有,则继续去B类中找,如果B类中么有,则继续去C类中找,如果C类中么有,则继续去D类中找,如果还是未找到,则报错
# 所以,查找顺序:A --> B --> C --> D
# 在上述查找bar方法的过程中,一旦找到,则寻找过程立即中断,便不会再继续找了
a.bar()

  经典类:首先去A类中查找,如果A类中没有,则继续去B类中找,如果B类中么有,则继续去D类中找,如果D类中么有,则继续去C类中找,如果还是未找到,则报错

  新式类:首先去A类中查找,如果A类中没有,则继续去B类中找,如果B类中么有,则继续去C类中找,如果C类中么有,则继续去D类中找,如果还是未找到,则报错

  注意:在上述查找过程中,一旦找到,则寻找过程立即中断,便不会再继续找了

三、多态(Pyhon不支持Java和C#这一类强类型语言中多态的写法,但是原生多态,其Python崇尚“鸭子类型”。)

# Python的鸭子类型
class Duck(object):      #Duck类型

    def walk(self):
        print(‘i am a duck,and i can walk‘)

    def swim(self):
        print(‘i am a duck,and i can swim‘)

class Cat(object):      #Cat类型

    def walk(self):
        print(‘i am a cat,and i can walk‘)

    def swim(self):
        print(‘i am a cat,and i can swim‘)

# 实现一个动物walk和swim的功能函数
def walk_swim(animal):
    animal.walk()
    animal.swim()

d = Duck()
c = Cat()

walk_swim(d)
walk_swim(c)

以上就是本节对于面向对象初级知识的介绍,总结如下:

  • 面向对象是一种编程方式,此编程方式的实现是基于对  和 对象 的使用
  • 类 是一个模板,模板中包装了多个“函数”供使用
  • 对象,根据模板创建的实例(即:对象),实例用于调用被包装在类中的函数
  • 面向对象三大特性:封装、继承和多态

原文地址:https://www.cnblogs.com/leixiaobai/p/10128038.html

时间: 2024-09-29 16:46:09

Python全栈开发记录_第九篇(类的基础_封装_继承_多态)的相关文章

Python全栈开发记录_第一篇

Python全栈开发记录只为记录全栈开发学习过程中一些难和重要的知识点,还有问题及课后题目,以供自己和他人共同查看.(代码行数:70行) 知识点1:优先级:not>and 短路原则:and:如果第一个条件的结论为假,那么 and 前后两个条件组成的表达式计算结果一定为假,后面的条件计算机不会进行计算 or:如果第一个条件的结论为真,那么or 前后两个条件组成的表达式计算结果一定为真,后面的条件计算机不会进行计算 知识点2:python区分大小写,常量需全部字母大写(默认这样写) python换行

Python全栈开发记录_第八篇(模块收尾工作 json & pickle & shelve & xml)

由于上一篇篇幅较大,留下的这一点内容就想在这里说一下,顺便有个小练习给大家一起玩玩,首先来学习json 和 pickle. 之前我们学习过用eval内置方法可以将一个字符串转成python对象,不过,eval方法是有局限性的,对于普通的数据类型,json.loads和eval都能用,但遇到特殊类型的时候,eval就不管用了,所以eval的重点还是通常用来执行一个字符串表达式,并返回表达式的值. 什么是序列化? 我们把对象(变量)从内存中变成可存储或传输的过程称之为序列化,在Python中叫pic

Python全栈开发记录_第五篇(装饰器)

单独记录装饰器这个知识点是因为这个知识点是非常重要的,必须掌握的. 了解装饰器之前要知道三个知识点 作用域,上一篇讲到过顺序是L->E->G->B 高阶函数: 满足下列其中一种即可称之为高阶函数: a.把一个函数名当做实参传递给另一个函数 b.返回值中包含函数名 3.闭包 闭包是由函数及其相关的引用环境组合而成的实体(即:闭包=函数+引用环境),通俗讲法是:在一个外函数中定义了一个内函数,内函数里运用了外函数的临时变量,并且外函数的返回值是内函数的引用.这样就构成了一个闭包.,具体看下面

python全栈开发【第十篇】Python常用模块二(时间、random、os、sys和序列化)

一.time模块 表示时间的三种方式: 时间戳:数字(计算机能认识的) 时间字符串:t='2012-12-12' 结构化时间:time.struct_time(tm_year=2017, tm_mon=8, tm_mday=8, tm_hour=8, tm_min=4, tm_sec=32, tm_wday=1, tm_yday=220, tm_isdst=0)像这样的就是结构化时间 #time模块的常用方法及三种时间之间的转换 import time # 对象:对象.方法 # --------

python全栈开发【第四篇】Python流程控制

十二 流程控制之if-else 既然我们编程的目的是为了控制计算机能够像人脑一样工作,那么人脑能做什么,就需要程序中有相应的机制去模拟.人脑无非是数学运算和逻辑运算,对于数学运算在上一节我们已经说过了.对于逻辑运算,即人根据外部条件的变化而做出不同的反映,比如 1 如果:女人的年龄>30岁,那么:叫阿姨 age_of_girl=31 if age_of_girl > 30: print('阿姨好') 2 如果:女人的年龄>30岁,那么:叫阿姨,否则:叫小姐 age_of_girl=18

python全栈开发【第六篇】Python字符编码

1.内存和硬盘都是用来存储的. CPU:速度快 硬盘:永久保存 2.文本编辑器存取文件的原理(nodepad++,pycharm,word) 打开编辑器就可以启动一个进程,是在内存中的,所以在编辑器编写的内容也都是存放在内存中的,断电后数据就丢失了.因而需要保存在硬盘上,点击保存按钮或快捷键,就把内存中的数据保存到了硬盘上.在这一点上,我们编写的py文件(没有执行时),跟编写的其他文件没有什么区别,都只是编写一堆字符而已. 3.python解释器执行py文件的原理,例如python  test.

python全栈开发【第十一篇】Python常用模块三(hashlib,configparser,logging)

hashlib模块 hashlib提供了常见的摘要算法,如md5和sha1等等. 那么什么是摘要算法呢?摘要算法又称为哈希算法.散列算法.它通过一个函数,把任意长度的数据转换为一个长度固定的数据串(通常用16进制的字符串表示). 注意:摘要算法不是一个解密算法.(摘要算法,检测一个字符串是否发生了变化) 应涂:1.做文件校验 2.登录密码 密码不能解密,但可以撞库,用'加盐'的方法就可以解决撞库的问题.所有以后设置密码的时候要设置的复杂一点. #用户密码 import hashlib # md5

python全栈开发【第十三篇】Python面向对象

一.面向过程:面向过程的程序设计的核心是过程(流水线式思维),过程即解决问题的步骤,面向过程的设计就好比精心设计好一条流水线,考虑周全什么时候处理什么东西. 优点:极大地降低了写成学的复杂度,只需要顺着执行的步骤,堆叠代码即可 缺点:一套流水线或者流程就是用来解决一个问题,如果修改代码就都得改变 二.面向对象:上帝的思想 优点:解决了程序的扩展性.对某一个对象单独修改,会立刻反映到整个体系中,如对游戏中一个人物参数的特征和技能修改都很容易. 缺点:可控性差,无法向面向过程的程序设计流水线式的可以

python全栈开发【第十七篇】面向对象反射和内置方法

一.静态方法(staticmethod)和类方法(classmethod) 类方法:有个默认参数cls,并且可以直接用类名去调用,可以与类属性交互(也就是可以使用类属性) 静态方法:让类里的方法直接被类调用,就像正常调用函数一样 类方法和静态方法的相同点:都可以直接被类调用,不需要实例化 类方法和静态方法的不同点: 类方法必须有一个cls参数表示这个类,可以使用类属性 静态方法不需要参数 绑定方法:分为普通方法和类方法 普通方法:默认有一个self对象传进来,并且只能被对象调用-------绑定