组合与重用性:
组合指的是,在一个类中以另外一个类的对象作为数据属性,称为类的组合
组合和减少代码的重复量,组合与继承都是有效地利用已有类的资源的重要方式。但是二者的概念和使用场景皆不同。
继承的方式
通过继承建立了派生类与基类之间的关系,它是一种’是’的关系,比如白马是马,人是动物。
当类之间有很多相同的功能,提取这些共同的功能做成基类,用继承比较好,比如老师是人,学生是人
class People:
def __init__(self,name,age,sex):
self.name=name
self.age=age
self.sex=sex
def tell_info(self):
print('name:%s age:%s sex:%s' %(self.name,self.age,self.sex))
class Teacher(People):
def __init__(self,name,age,sex,salary):
super().__init__(name,age,sex)
self.salary=salary
class Student(People):
def __init__(self,name,age,sex,class_mes):
super().__init__(name,age,sex)
self.class_mes=class_mes
teacher1=Teacher('sanzang',666,'male',5000)
student1=Student('sunwukong',130,'male',20190906)
teacher1.tell_info()
student1.tell_info()
#name:sanzang age:666 sex:male
#name:sunwukong age:130 sex:male
上述代码,老师和学生都是人,所以他们都继承人的属性‘姓名’,‘年龄’,‘性别’
组合的方式
用组合的方式建立了类与组合的类之间的关系,它是一种‘有’的关系,比如老师需要给学生上课,学生有课;相当于二者都有课这一属性。但是课程里面又包含课程名,上课地点,时间三个属性。
class People:
def __init__(self,name,age,sex):
self.name=name
self.age=age
self.sex=sex
def tell_info(self):
print('name:%s age:%s sex:%s' %(self.name,self.age,self.sex))
class Teacher(People):
def __init__(self,name,age,sex,salary):
super().__init__(name,age,sex)
self.salary=salary
class Student(People):
def __init__(self,name,age,sex,class_mes):
super().__init__(name,age,sex)
self.class_mes=class_mes
class Course():
def __init__(self,name,time,site):
self.name=name
self.time=time
self.site=site
teacher1=Teacher('sanzang',666,'male',5000)
student1=Student('sunwukong',130,'male',20190906)
course1=Course('python','每周三','11号楼')
teacher1.course=course1 #等价于teacher1.course.append(course1)
student1.course=course1 #等价于student1.course.append(course1)
print(student1.__dict__)
print(teacher1.__dict__)
# {'name': 'sunwukong', 'age': 130, 'sex': 'male', 'class_mes': 20190906,
# 'course': <__main__.Course object at 0x000001A8D743F6A0>}
# {'name': 'sanzang', 'age': 666, 'sex': 'male', 'salary': 5000,
# 'course': <__main__.Course object at 0x000001A8D743F6A0>}
print(student1.course.name)
print(teacher1.course.time)
# python
# 每周三