Python之面向对象总计

2019-10-22 11:42栏目:王中王今日开奖结果
TAG:

黄金时代、面向对象

   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,并且能够一贯用类名去调用,能够与类属性交互(也便是可以利用类属性)

               2、静态方法:让类里的主意间接被类调用,就像正规调用函数同样

           b、类措施和静态方法的同样点:都得以平昔被类调用,无需实例化

           c、类措施和静态方法的不一致点:

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

           静态方法无需参数

           d、绑定方法:分为普通方法和类措施

     普通方法:私下认可有贰个self对象传进来,何况不得不被对象调用-------绑定到对象

     类方法:私下认可有贰个cls对象传进来,並且能够被类和对象(不引入)调用-----绑定到类

            e、非绑定方法:静态方法:未有设置暗中认可参数,况兼能够被类和对象(不推荐)调用-----非绑定

    16、接口类与抽象类

             a、 接口类:(在抽象类的功底上)

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

                    接口类无法被实例化(假如实例化会报错)

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

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

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

           b、抽象类

在python中,默认是有的

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

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

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

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

抽象类和接口类的使用:

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

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

 

版权声明:本文由493333王中王开奖结果发布于王中王今日开奖结果,转载请注明出处:Python之面向对象总计