2、面向对象

风流倜傥、面向对象

   1、面向进度

     
 a、优点:相当的大的减退了写程序的复杂度,只需求顺着实践的步子,堆成堆代码就可以

     
 b、瑕玷:风流洒脱套流水生产线大概流程就是来消除一个主题材料,代码正是牵一发而南京全身

   2、面向对象

     
 a、优点:清除程序的扩张性,对某三个对象单独改良,会登时反应到全体系统中

     
 b、短处:可控性差,不可能向面向进度的顺序设计流水生产线式的能够很精准的眺望难题的拍卖流程与结果,面向对象的主次风流倜傥旦领头就有对象时期的相互作用消除难点。

   3、 类:具备同样特征的风姿罗曼蒂克类东西(人、狗、黑蓝虎)

   4、对象/实例:具体的某多个东西(隔壁阿花、楼下旺财卡塔 尔(阿拉伯语:قطر‎

   5、实例化:类——>对象的长河

   6、
在python中,用变量表示特征,用函数表示本事,因此具备同等特征和才干的大器晚成类东西正是‘类’,

   7、对象是则是那豆蔻梢头类东西中切实的二个

class Person:   #定义一个人类
    role = 'person'  #人的角色属性都是人
    def walk(self):  #人都可以走路,也就是有一个走路方法,也叫动态属性
        print("person is walking...")

class 类名:
    类属性 = None
    def __init__(self,对象属性):
        self.对象属性 = 对象属性

    def 方法名(self):
        pass

实例 = 类名(10)
实例.方法名()

    8、类的三种效应:属性引用和实例化

    9、属性援用(类名.属性卡塔 尔(阿拉伯语:قطر‎

class Person:   #定义一个人类
    role = 'person'  #人的角色属性都是人
    def walk(self):  #人都可以走路,也就是有一个走路方法
        print("person is walking...")


print(Person.role)  #查看人的role属性
print(Person.walk)  #引用人的走路方法,注意,这里不是在调用

   
10、例化:类名加括号正是实例化,会自行触发__init__函数的周转,能够用它来为种种实例定制自身的表征

class Person:   #定义一个人类
    role = 'person'  #人的角色属性都是人
    def __init__(self,name):
        self.name = name  # 每一个角色都有自己的昵称;

    def walk(self):  #人都可以走路,也就是有一个走路方法
        print("person is walking...")


print(Person.role)  #查看人的role属性
print(Person.walk)  #引用人的走路方法,注意,这里不是在调用

    11、

类名
    类名.类属性
   类名.方法名

实例 = 类名(参数,参数)  #实例就是对象

实例
    实例.方法名()
   实例.对象属性

实例增加属性
实例.新的属性名 = 1000
print(实例.新的属性名)

   12、关于self

self:在实例化时自动将对象/实例本身传给__init__的第一个参数,你也可以给他起个别的名字.

对象/实例只有一种作用:属性引用

class 类名:
    def __init__(self,参数1,参数2):
        self.对象的属性1 = 参数1
        self.对象的属性2 = 参数2

    def 方法名(self):pass

    def 方法名2(self):pass

对象名 = 类名(1,2)  #对象就是实例,代表一个具体的东西
                  #类名() : 类名+括号就是实例化一个类,相当于调用了__init__方法
                  #括号里传参数,参数不需要传self,其他与init中的形参一一对应
                  #结果返回一个对象
对象名.对象的属性1   #查看对象的属性,直接用 对象名.属性名 即可
对象名.方法名()     #调用类中的方法,直接用 对象名.方法名() 即可

dir(类) #返回类中的所有名字列表
isinstance(对象,类) #判断对象是否为类的实例
print(Person.__dict__) # 返回一个字典 key是属性名,value是属性值
print(Person.__module__)  #person类所在的模块
print(Person.__name__,type(Person.__name__)) #字符串数据类型的类名

     13、类命名空间与目的、实例的命名空间

         
 a、冷眼旁观贰个类就能够创制贰个类的名号空间,用来积攒类中定义的有着名字,那几个名字成为类的特性

           b、而类有三种属性:静态属性和动态属性

  •  静态属性正是间接在类中定义的变量
  • 动态属性正是概念在类中的方法

始建一个对象/实例就能够创立二个指标/实例的名称空间,存放对象/实例的名字,称为对象/实例的性子

面容对象的组合用法:

组合指的是,在三个类中以其它一个类的靶子作为数据属性,称为类的组

列子:

图片 1图片 2

from  math  import pi
class Circular:
    def __init__(self,radius):
        self.radius=radius
    def area(self):
        return self.radius **2 * pi
    def perimeter(self):
        return 2 * self.radius * pi
circu=Circular(10)
print(circu.area())
print(circu.perimeter())

圆的周长与面积

     14、面向对象的三大特色

           a、继承

class Animal:      #父类  基类  超类
    def __init__(self,name,life_value,aggr):
        self.name = name
        self.life_value = life_value
        self.aggr = aggr


class Person(Animal):  #子类  派生类
    pass

class Dog(Animal): #子类  派生类
    pass

egg = Person('egon',1000,50)
print(egg.name)
print(egg.aggr

       

python2
class Dad:  #经典类
class Dag(object)  #新式类

python3
class Dad  ==  class Dag(object) #新式类

              1、世襲的语法

 class 类名(父类名):
      想在子类中实现调用父类的方法
      在类内 ——super(子类名,self).方法名()
      在类外面 ——super(子类名,对象名).方法名()
      如果不指定继承的父类,默认继承object
      子类可以使用父类的所有属性和方法
      如果子类有自己的方法就执行自己的的
      如果是子类没有的方法就执行父类的
      如果子类父类都没有这个方法就报错

继承、抽象、派生
继承 是从大范围到小范围
抽象 小范围到大范围
派生 就是在父类的基础上又产生子类——派生类
        父类里没有的 但子类有的 ——派生方法
        派生属性
方法的重写
    父类里有的方法,在子类里重新实现

 

              2、世襲的两用:                

                 
b:世襲基类的议程,而且做出本身的退换依然扩充(代码重用卡塔尔***
  ***

                 
a:注脚某些子类包容于某基类,定义多个接口类Interface,接口类中定义

                       
 **
 了一些接口名(正是函数名卡塔尔国且还没有完结接口的功用,子类继世袭口类,何况完成接口中的功效**

           b、封装

                  1、优点:

                              a、将转变隔绝

                              b、封装使用

                              c、提升复用性

                              d、升高安全性

                  2、封装原则:

                              a、将无需对外提供的从头到尾的经过都走避起来

                              b、把品质都掩盖起来提供公共措施对其访谈

                  3、私有变量和个体方法

                             
a、在python中用双写道的开端的的措施降属性隐敝起来(设置个人的卡塔 尔(阿拉伯语:قطر‎

property属性

property是生龙活虎种特其他质量,访谈它时会实施黄金年代段成效(函数卡塔尔然后再次回到值

  

         
 c、多态:”多态指的是生机勃勃类东西有多样形象(比方:老师.下课铃响了(卡塔尔国,学子.下课铃响了(),老师推行的是下班操作,学子实施的是放学操作,即便双方消息未有差距于,然则进行的意义差别卡塔 尔(阿拉伯语:قطر‎

                   多态指的是:豆蔻年华类玩意儿有多种场地

python自带多态:

  多态:同一类事物的多种状态

  python里处处都是多态,只是我们一般发现不了

  操作的时候不需要关心这个对象的数据类型,你只要用就行了

 

    15、反射     

        1、
反射:能够用字符串的不二等秘书籍去拜谒对象的性质,调用对象的形式(可是无法去做客方法卡塔尔国,python中全体皆对象,都能够使用反射。

        2、反射有八种方法:

             
 hasattr:hasattr(object,name卡塔尔国决断三个对象是或不是有name属性或然name方法。有就赶回True,没有就回到False

             
getattr:获取对象的质量只怕措施,假使存在则打字与印刷出来。hasattr和getattr配套使用

                
要求小心的是,假若回到的是目的的办法,重返出来的是指标的内部存款和储蓄器地址,即使急需周转这几个法子,能够在后头增添风度翩翩对(卡塔尔

               setattr:给目的的性格赋值,若属性一纸空文,先创建后赋值

               delattr:删除该对象钦命的两本性能

          a、内置方法:isinstance和issubclass

               isinstance(obj,cls)检查是不是obj是不是是类 cls
的对象

class Foo:
    pass
class Son(Foo):
    pass
s=Son()

print(isinstance(s,Son))

        b、内置方法:issubclass(sub, super)检查sub类是不是是
super 类的派生类 

class Foo(object):
    pass

class Bar(Foo):
    pass

issubclass(Bar, Foo)

 

     
 c、python面向对象中的反射:通过字符串的花样操作对象相关的属性,python中整整事物都是指标(都得以用反射卡塔尔

检查是否含有某属性---hasattr 返回布尔值
获取属性---getattr   没有就会报错
设置属性---setattr
删除属性---delattr

       d、内置方法:__del__

析构方法,当对象在内部存款和储蓄器中被放走时,自动触发推行。

注:此情势平时不要定义,因为Python是一门高档语言,程序猿在应用时无需关切内部存款和储蓄器的分红和刑释,因为此专门的工作都以交由Python解释器来执行,所以,析构函数的调用是由解释器在进行垃圾回收时自动触发执行的。

class Foo:
    def __del__(self):
        print('fgs')
f=Foo()
print(123)
print(123)
del f
print(123)
print(123)
print(123)

 

     e、内置方法:item系列

__getitem__\__setitem__\__delitem__

    __new__

class A:
    def __init__(self):  #有一个方法在帮你创造self
        print('in init function')
        self.x=1
    def __new__(cls, *args, **kwargs):
        print('in init funct')
        return object.__new__(A,*args,**kwargs)
a=A()

     f、__str__和__repr__改换目的的字符串突显

图片 3图片 4

class Foo:
 2     def __init__(self,name):
 3         self.name = name
 4     def __repr__(self):
 5         return 'obj in str'  #这里只能是return
 6     # def __str__(self):
 7     #     return '%s obj in str'%self.name
 8 f = Foo('egon')
 9 print(f)  #优先执行__str__里面的内容
10 # 那么你是不是据地__repr__没用呢?
11 # print('%s'%f)  #执行的是__str__里面的返回值
12 # print('%r'%f)  #执行的是__repr__里面的返回值
13 print('==============')
14 print(str(f))  #当执行str(f)时,会去找__str__这个方法,如果找不到的时候,__repr__这个方法就给替补了
15 print(repr(f))
16 #1.当打印一个对象的时候,如果实现了__str__方法,打印__str__中的返回值
17 # 2.当__str__没有被实现的时候,就会调用__repr__方法
18 # 3.但是当你用字符串格式化的时候,%s和%r会分别调用__str__和__repr__方法
19 # 4.不管是在字符串格式化的时候还是在打印对象的时候,
20 # __repr__方法都可以作为__str__方法的替补,但反之则不行
21 # 5.用于友好的表示对象。如果__str__和__repr__方法你只能实现一个:先实现__repr__

__str__,__repr__

    15、内置方法

           a、静态方法和类格局

             
 1、类情势:有个默许参数cls,况兼能够一向用类名去调用,能够与类属性交互作用(也正是足以选取类属性卡塔 尔(英语:State of Qatar)

             
 2、静态方法:让类里的方法直接被类调用,就如正规调用函数同样

           b、类措施和静态方法的相符点:都足以直接被类调用,无需实例化

           c、类措施和静态方法的差别点:

          类方法必需有三个cls参数表示这一个类,能够使用类属性

           静态方法无需参数

           d、绑定方法:分为普通方法和类情势

     普通方法:私下认可有一个self对象传进来,并且不能不被对象调用——-绑定到目的

     类方法:暗中同意有三个cls对象传进来,而且能够被类和对象(不推荐卡塔尔国调用—–绑定到类

           
e、非绑定方法:静态方法:未有设置默认参数,并且能够被类和对象(不推荐卡塔 尔(英语:State of Qatar)调用—–非绑定

    16、接口类与抽象类

             a、 接口类:(在抽象类的根底上卡塔尔

         在python中,默许是绝非接口类的           

                    接口类不能被实例化(若是实例化会报错卡塔尔国

          接口类中的方法不可能被完结

接口也就是做约束,让下面的类的方法都按照接口类中给出的方法去定义。如果接口类里面有的方法类里面没有,那么那个类就不能被实例化。(字面理解)

继承的第二种含义非常重要。它又叫“接口继承”。
接口继承实质上是要求“做出一个良好的抽象,这个抽象规定了一个兼容接口,使得外部调用者无需关心具体细节,可一视同仁的处理实现了特定接口的所有对象”——这在程序设计上,叫做归一化。

           b、抽象类

在python中,默认是有的

    父类的方法,子类必须实现

    抽象类(父类)的方法可以被实现

抽象类和接口类的区别:接口类不能实现方法,抽象类可以实现方法里面的内容

抽象类和接口类的相同点:都是用来做约束的,都不能被实例化

抽象类和接口类的使用:

  当几个子类的父类有相同的功能需要被实现的时候就用抽象类

  当几个子类有相同的功能,但是实现各不相同的时候就用接口类

 

相关文章