Python基础 面向对象的三大特征(封装、继承、多态)二,继承和多态、深拷贝和浅拷贝

面向对象的三大特征
    一:封装:提高程序的安全性
        1.将数据(属性)和行为(方法)包装到类对象中。在方法内部对属性进行操作,在类对象的外部调用方法。
        这样,无需关心方法内部的具体实现细节,从而隔离了复杂度。
        2.在Python中没有专门的修饰符用于属性的私有,如果该属性不希望在类对象外部被访问,前边使用两个"_",如__age
    二:继承:提高代码的复用性
    三:多态:提高程序的可扩展性

继承
语法格式:
class 子类类名(父类1,父类2)   #定义类时不写括号继承默认继承object,python支持多继承,父类可以写多个
pass

1.如果一个类没有继承任何类,则默认继承object
2.python支持多继承
定义子类时,必须在其构造函数中调用父类的构造函数

继承

#继承
class Person(object):  #Person继承object类,也可以不写,不写的话就是class Person: 这样就默认继承object类
    def __init__(self,name,age):
        self.name=name
        self.age=age
    def info(self):
        print(self.name,self.age)

class Student(Person):    #Student类继承上面的Person类
    def __init__(self,name,age,stu_no):
        #super()函数是用来调用父类(超类)的一种方法,超类就是父类
        super().__init__(name,age)   #使用super()去调用父类的__init__方法,然后把name和age传入
        self.stu_no=stu_no

class Teacher(Person):   #Teacher类继承上面的Person类
    def __init__(self,name,age,teachofyear):
        super().__init__(name,age)    #使用super()去调用父类的__init__方法,然后把name和age传入
        self.teachofyear=teachofyear

stu=Student("张三",20,"1001")    #创建stu学生类的对象,并给初始化属性传入数据
tecaher=Teacher("李四",34,10)    #创建tecaher老师类的对象

stu.info()    #调用父类继承过来的info方法,因为父类的方法已经无法满足子类的需求,所以只输出了,张三 20
tecaher.info()  #调用父类继承过来的info方法,李四 34

方法重写:
若子类想输出自己独有的东西,父类无法提供此需求了,就可以自己来重写方法

1.如果子类对继承自父类的某个属性或方法不满意,可以在子类中对其(方法体进行重新编写)
2.子类重写后的方法中可以通过super().xxx()调用父类中被重写的方法
#复制上面的代码,进行方法重写
class Person(object):  #Person继承object类,也可以不写,不写的话就是class Person: 这样就默认继承object类
    def __init__(self,name,age):
        self.name=name
        self.age=age
    def info(self):
        print(self.name,self.age)

class Student(Person):    #Student类继承上面的Person类
    def __init__(self,name,age,stu_no):
        #super()函数是用来调用父类(超类)的一种方法,超类就是父类
        super().__init__(name,age)   #使用super()去调用父类的__init__方法,然后把name和age传入
        self.stu_no=stu_no
    #方法重写
    def info(self):   #在Student类中重新编写父类方法
        super().info()    #super().xxx()调用父类中被重写的方法
        print("学号:{0}".format(self.stu_no))

class Teacher(Person):   #Teacher类继承上面的Person类
    def __init__(self,name,age,teachofyear):
        super().__init__(name,age)    #使用super()去调用父类的__init__方法,然后把name和age传入
        self.teachofyear=teachofyear
    #方法重写,让父类方法满足子类独有的方法
    def info(self):
        super().info()
        print("教龄是:{0}".format(self.teachofyear))   #{0}表示占位符,0是索引,表示format()里的第一个元素

stu=Student("张三",20,"1001")    #创建stu学生类的对象,并给初始化属性传入数据
tecaher=Teacher("李四",34,10)    #创建tecaher老师类的对象

stu.info()
tecaher.info()
多态
简单地说,多态就是"具有多种形态",它指的是:几遍不知道一个变量所引用的对象到底是什么类型,任然可以通过这个变量调用方法,
在运行过程中根据变量所应用对象类型,动态决定调用哪个对象中的方法。

变量的赋值操作:

知识形成两个变量,实际上还是指向同一个对象

import copy

浅拷贝(copy):

Python拷贝一般都是浅拷贝,拷贝时,对象包含的子对象内容不拷贝,因此,原对象拷贝与对象会引用同一个子对象。

浅拷贝就像是给原对象创建了一个快捷方式,改变这个对象时,原对象也会改变。也可以说是新瓶装旧酒。

使用copy模块里面的copy方法实现。

改变原始对象中为可变类型的元素的值,会同时影响拷贝对象;

改变原始对象中为不可变类型的元素的值,不会响拷贝对象。

深拷贝(deepcopy):

使用copy模块的deepcopy函数,递归拷贝对象中包含的子对象,源对象和拷贝对象所有的子对象也不同。

深拷贝就像是将原对象复制粘贴一份,形成两份一模一样的独立对象,但之后改变对象时,原对象不受影响,因为两个对象时独立的,也可以比喻成新瓶装新酒。

其实copy()与deepcopy()之间的区分必须要涉及到python对于数据的存储方式。

copy模块里面的deepcopy方法实现。

深拷贝,除了顶层拷贝,还对子元素也进行了拷贝。

原始对象和拷贝对象所有的可变元素地址都不一样了。

Python深拷贝和浅拷贝的总结:

1,深浅拷贝都是对源对象的复制,占用不同的内存空间。

2,不可变类型的对象,对于深浅拷贝毫无影响,最终的地址值和值都是相等的。

3,可变类型的对象:值相等,地址不相等 。

  • 4
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Python-派大星

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值