继承、多态、多态性

1.什么是继承?继承是一种创建新的类的方式

class A:
	pass
	
class B(A):
	pass

2.如何继承-》如何寻找继承关系

继承是一种‘是’的关系:

人类、猪类、狗类都继承动物类,因而他们都是动物

3.为什么要用继承?

解决代码重用问题?
解决的是:什么是什么的问题-》继承

4.派生:子类继承了父类的属性,然后衍生出自己新的属性,

	如果子类衍生出的新的属性与父类的某个属性名字相同,
	那么再调用子类的这个属性,就以子类自己这里的为准了

5.在子类中重用父类的函数:父类名.父类的函数(参数)或者super

class A:
	def test(self):
		print("This is A !")
	
class B(A):
	def test(self):
		A.test(B)
		#super().test()  #如果在python2中super需要跟参数:super(B,self).test()
		print("This is B !")

b=B()
b.test()

6.组合对比继承来说,也是用来重用代码,但是组合描述的是一种“有”的关系

老师有课程

学生有成绩

学生有课程

学校有老师

学校有学生

class Course:
	def __init__(self,name,price,period):
		self.name=name
		self.price=price
		self.period=period
		
class Teacher:
	def __init__(name,course):
		self.name=name
		self.course=course
		
class Student:
	def __init__(name,course):
		self.name=name
		self.course=course
python=Course('python',15800,'7m')
t1=Teacher('egon',python)
s1=Student('alex',python)


print(s1.course.name)
print(s1.course.period)

7、多态:同一种事物的多种形态,动物分为人类,猪类(在定义角度)

class Animal:
    def run(self):
        raise AttributeError('子类必须实现这个方法')


class People(Animal):
    def run(self):
        print('人正在走')

class Pig(Animal):
    def run(self):
        print('pig is walking')


class Dog(Animal):
    def run(self):
        print('dog is running')

peo1=People()
pig1=Pig()
d1=Dog()

peo1.run()
pig1.run()
d1.run()

多态性:一种调用方式,不同的执行效果(多态性)

def func(obj):
    obj.run()

func(peo1)
func(pig1)
func(d1)


多态性依赖于:
     1.继承
     2.
多态性:定义统一的接口,

def func(obj): #obj这个参数没有类型限制,可以传入不同类型的值
    obj.run() #调用的逻辑都一样,执行的结果却不一样


func(peo1)
func(pig1)

func(d1)

继承:

python3中只有新式类。遵循:广度优先。

 class A(object):
     def test(self):
         print('from A')
     pass

 class B(A):
      def test(self):
         print('from B')
     pass

 class C(A):
      def test(self):
          print('from C')
     pass

 class D(B):
      def test(self):
          print('from D')
     pass

 class E(C):
      def test(self):
          print('from E')
     pass

 class F(D,E):
      def test(self):
          print('from F')
     pass

 f1=F()
 f1.test()

 print(F.__mro__)   #会返回继承顺序的一个列表
 print(F.mro())     #同上

#广度优先:F->D->B->E->C->A->object

会找到倒数第二层,再找其他分支,全部分支找完再找最底层,2

python2中有经典类又有新式类。经典类遵循:深度优先。

class A:
     def test(self):
         print('from A')
     pass

class B(A):
     def test(self):
         print('from B')
     pass

class C(A):
     def test(self):
         print('from C')
     pass

class D(B):
     def test(self):
         print('from D')
     pass

class E(C):
     def test(self):
         print('from E')
     pass

class F(D,E):
     def test(self):
         print('from F')
     pass

f1=F()
f1.test()

#深度优先 F->D->B->A->E->C   经典类中没有mro()方法

优先找完一整条路,再找另外一条。

posted @ 2017-04-24 16:41  高跃  阅读(311)  评论(0编辑  收藏  举报