一. 继承
1.什么是继承
"""
让子类直接拥有父类的属性和方法的过程就是继承
子类 - 继承者
父类 - 被继承者(又叫超类)
"""
2.怎么继承
"""
class 类名(父类1,父类2,父类3,...):
类的说明文档
类的内容
说明:
1)默认情况下,类继承自object:
class 类名: == class 类名(object)
2)python中的类支持多继承
"""
class Person:
num = 61
def __init__(self, name='张三', age=18, gender='男'):
self.name = name
self.age = age
self.gender = gender
self.__id = '001'
def eat(self, food='馒头'):
print(f'{self.name}在吃{food}')
@staticmethod
def func1():
print('静态方法')
class Student(Person):
pass
3.继承可以让子类直接拥有父类所有的属性和方法
print(Student.num)
stu = Student()
print(stu.name, stu.age, stu.gender)
stu.eat('肉包子')
Student.func1()
print(stu.__dict__)
2.怎么在子类添加内容
"""
1)添加类属性和方法
直接在子类中定义
2)添加对象属性
需要在子类的__init__方法中通过super()去调用父类的__init__方法
注意:super()只能在对象方法和类方法中使用
"""
class Animal:
num = 100
def __init__(self):
self.age = 0
self.gender = '雌'
def eat(self, food='草'):
print(f'动物吃{food}')
@classmethod
def func3(cls):
print('hello!动物!')
class Cat(Animal):
# 添加字段
x = 'abc'
num = 10
# 添加方法
def play(self):
print('猫在玩毛线')
def eat(self, food='鱼'):
print(f'猫在吃{food}')
@classmethod
def func3(cls):
super().func3()
print('hello,小猫')
# 添加对象属性
def __init__(self):
# super().父类的方法
super().__init__()
self.name = '花花'
# @staticmethod
# def func2():
# 注意:静态方法中不能使用super()
cat = Cat()
print(Cat.num, Cat.x)
cat.eat()
cat.play()
print(cat.name)
print(cat.age, cat.gender)
Cat.func3()
# 练习:定义一个教师类在Person类的基础上添加职称和工龄连两个属性,
# 并且创建教师对象的时候必须给名字、职称和性别赋值,年龄和工龄可以赋值可以不赋值
class Person:
def __init__(self, name, age=18, gender='男'):
self.name = name
self.age = age
self.gender = gender
class Teacher(Person):
def __init__(self, name, job_title, gender, age=18, work_age=0):
super().__init__(name, age, gender)
self.job_title = job_title
self.work_length = work_age
def __repr__(self):
return f'<{str(self.__dict__)[1:-1]}>'
t1 = Teacher('小明', '讲师', '男')
t2 = Teacher('小花', '讲师', '女', age=25, work_age=16)
print(t1)
print(t2)
二. 内存管理
"""
定义变量保存数据的时候系统会自动在内存中开辟空间保存数据(空间的大小根据数据大小来确定)。
默认情况下,使用的数据如果之前已经保存过,还是会重新申请新的内存保存这个数据,但是数字和字符串例外。
一个数据是否需要释放就看就这个数据的引用计数是否为0(是否有引用),
如果不为0(有引用)数据不会销毁,为0(没有引用)数据会自动销毁
"""
class Person:
def __init__(self, name='小明', age=18):
self.name = name
self.age = age
p1 = Person()
p2 = p1
list1 = [100, p1]
# 拷贝
class Dog:
def __init__(self, name='大黄', age=3):
self.name = name
self.age = age
def __repr__(self):
return f'<{str(self.__dict__)[1:-1]}>'
class Person:
def __init__(self, name='小明', dog=None):
self.name = name
self.dog = dog
def __repr__(self):
return f'<{str(self.__dict__)[1:-1]}, id:{id(self)}>'
from copy import copy, deepcopy
p1 = Person(dog=Dog())
# 直接赋值:赋的是地址,赋值完成后两个变量的地址相同
# p2 = p1
# print(p1, p2)
# p1.name = '小花'
# p1.dog.name = '财财'
# print(p1, p2)
# # 浅拷贝
# p3 = copy(p1)
# print(p1, p3)
# p1.name = '小红'
# p1.dog.name = '财财'
# print(p1, p3)
#
# 深拷贝
p4 = deepcopy(p1)
print(p1, p4)
p1.name = '张三'
p1.dog.name = '财财'
print(p1, p4)