1.多继承
python中的类支持多继承(让一个类同时继承多个类);
多继承的时候,子类只能继承第一个父类所有的属性和方法,后面的父类中只有字段和方法可以被继承
class Animal(object):
num = 100
def __init__(self):
self.age = 0
self.gender = '雌'
@classmethod
def func1(cls):
print('动物类的类方法')
def func2(self):
print('动物类中的对象方法')
class Fly(object):
name = '飞行器'
def __init__(self):
self.height = 100
self.time = 5
self.speed = 100
def func2(self):
print('飞行的对象方法')
class Bird(Animal, Fly):
pass
bird1 = Bird()
字段都能继承
print(Bird.num, Bird.name)
Bird.func1()
bird1.func2()
# print(bird1.age, bird1.gender)
# print(bird1.speed, bird1.height, bird1.time)
=================================================================
import copy
1.运算符
python中所有的类型都是类,所以所有的数据都是对象;
python中使用任意的运算符都是在调用相应类中的相应方法,每一个运算符对应什么方法是固定的,
某种数据是否支持某个运算符操作就看这个数据类型中是否实现了对应的方法
2.运算符重载指的是在不同的类中实现同样的运算符对应的函数
类的对象默认情况下只支持: ==, !=
class Student:
def __init__(self, name, age, score=0):
self.name = name
self.age = age
self.score = score
def __repr__(self):
return '<%s, id:%s>' % (str(self.__dict__)[1:-1], hex(id(self)))
# a+b -> a.__add__(b)
# self -> 当前类的对象,也是+前面的那个数据
# other -> +后面的那个数据, 类型根据运算规则的设计可以是任何类型的数据
def __add__(self, other):
# return self.age + other.age
return self.score + other.score
# return Student(self.name+other.name, self.age+other.age, self.score + other.score)
# return self.score + other
# a*b -> a.__mul__(b)
def __mul__(self, other):
list = []
for _ in range(other):
list.append(copy.copy(self))
return list
# a<b -> a.__lt__(b)
# 注意: <和>符号只需要重载其中一个就可以
def __lt__(self, other):
return self.score < other.score
stu1 = Student('小明', 19, 90)
stu2 = Student('小花', 20, 78)
# stu1.__add__(stu2)
print(stu1 + stu2)
# stu1.__add__(100)
# print(stu1 + 100)
print(stu1 * 3)
students = [stu1, stu2, Student('小红', 12, 100)]
students.sort()
print(students)
print(stu1 < stu2)
print(stu1 > stu2)
==================================================================
from copy import copy, deepcopy
class Dog:
def __init__(self, name, color):
self.name = name
self.color = color
def __repr__(self):
return '<%s,id: %s>' % (str(self.__dict__)[1:-1], hex(id(self)))
class Person:
def __init__(self, name, age, dog=None):
self.name = name
self.age = age
self.dog = dog
def __repr__(self):
return '<%s,id: %s>' % (str(self.__dict__)[1:-1], hex(id(self)))
p1 = Person('小明', 18, Dog('大黄', '黄色'))
1.直接赋值
将变量中的地址直接赋给新的变量;赋值后两个变量的地址相同
p2 = p1
print(id(p1), id(p2)) # 4537270848 4537270848
p1.name = '小花'
print(p1.name, p2.name) # 小花 小花
p2.dog.color = '绿色'
print(p1.dog.color, p2.dog.color) # 绿色 绿色
2.拷贝
不管是浅拷贝还是深拷贝都会对原数据进行赋值产生新的地址
list1 = [1, 2, 3]
list2 = copy(list1)
list3 = deepcopy(list1)
print(id(list1), id(list2), id(list3))
==================================================================
from enum import Enum, unique
枚举值的特点:
1.可以通过有意义的属性名直接显示数据
2.每个数据的值不能修改
3.可以做到不同的数据的值唯一
@unique
确保数据值的唯一性
==================================================================
1.内存的开辟
内存区间分为栈区间和堆区间;栈区间的内存自动开辟自动释放,堆区间的内存需要程序员手动开辟,手动释放;
但是python已经将堆区间内存的开辟和释放自动化
a.当每次给变量赋值的时候,系统会先在堆区间中开辟空间将数据存起来,然后再将数据在堆中的地址存到变量中,变量存在栈区间;
b.数字和字符串数据在开辟空间的时候,会先检测内存中之前是否已经有这个数据,
如果有就直接使用之前的数据,没有才开辟新的空间保存数据
2.内存的释放
栈区间:全局栈区间在程序结束后销毁,函数栈区间在函数调用结束后销毁(自动)
堆区间: 看一个对象是否销毁,就看这个对象的引用计数是否为0;如果一个对象的引用为0,这个对象就会销毁;
(垃圾回收机制)
注意: python中针对对象的循环引用已经做了处理,程序员不需要写额外的代码来解决循环引用问题