Python之面向对象总结

   12、关于self

                              d、进步安全性

        2、反射有八种方式:

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__)) #字符串数据类型的类名

     
 a、优点:解决程序的扩充性,对某叁个目标单独校勘,会立刻反应到整连串统中

                              c、进步复用性

   4、对象/实例:具体的某三个东西(隔壁阿花、楼下旺财)

 

     
 c、python面向对象中的反射:通过字符串的款型操作对象相关的性质,python中总体育赛事物都是目的(都足以用反射)

property是意气风发种非凡的品质,访问它时会执行业作风流浪漫段成效(函数)然后再次来到值

       

class Foo(object):
    pass

class Bar(Foo):
    pass

issubclass(Bar, Foo)

        1、
反射:能够用字符串的点子去走访对象的习性,调用对象的主意(然则不可能去访谈方法),python中全部皆对象,都足以应用反射。

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

                             
a、在python中用双写道的上马的的方式降属性隐藏起来(设置个人的)

图片 1图片 2

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

    11、

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

          a、内置方法:isinstance和issubclass

     
 a、优点:非常大的减退了写程序的复杂度,只需求顺着实施的步调,积聚代码就能够

                              a、将扭转隔断

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

               isinstance(obj,cls卡塔尔(قطر‎检查是还是不是obj是还是不是是类 cls
的对象

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

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

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

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

   7、对象是则是这风度翩翩类东西中具体的三个

                       
 **
 了有个别接口名(正是函数名)且并未完成接口的功用,子类世襲袭口类,而且达成接口中的功效**

   6、
在python中,用变量表示特征,用函数表示工夫,由此具备相像特征和技能的生龙活虎类东西正是‘类’,

始建叁个对象/实例就能够制造八个指标/实例的称号空间,寄存对象/实例的名字,称为对象/实例的性质

析构方法,当指标在内部存款和储蓄器中被保释时,自动触发实行。

                              b、封装使用

圆的周长与面积

                 
a:评释有个别子类包容于某基类,定义贰个接口类Interface,接口类中定义

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

print(isinstance(s,Son))

长相对象的结合用法:

                 
b:继承基类的艺术,况兼做出本身的转移依旧增加(代码重用)***
  ***

                  3、私有变量和个人方法

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

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

     e、内置方法:item系列

生龙活虎、面向对象

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

注:此格局平日不要定义,因为Python是一门高端语言,程序猿在使用时无需关注内部存款和储蓄器的分配和假释,因为此干活都以付诸Python解释器来试行,所以,析构函数的调用是由解释器在张开垃圾回笼时自动触发实行的。

   5、实例化:类——>对象的历程

                              a、将无需对外提供的开始和结果都逃匿起来

             
 hasattr:hasattr(object,name)判定三个对象是还是不是有name属性可能name方法。有就回去True,未有就回去False

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

     13、类命名空间与对象、实例的命名空间

property属性

                
供给潜心的是,假诺回到的是指标的点子,重返出来的是指标的内部存款和储蓄器地址,如果供给周转那些法子,能够在背后增添大器晚成对()

         
 c、多态:”多态指的是风度翩翩类东西有五种形状(比方:老师.下课铃响了(),学子.下课铃响了(卡塔尔(قطر‎,老师实践的是下班操作,学子进行的是放学操作,即便两个信息无差异于,不过进行的功效差别)

     14、面向对象的三大特点

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

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

 

    15、反射     

           b、封装

                  2、封装原则:

列子:

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)  #引用人的走路方法,注意,这里不是在调用

                   多态指的是:大器晚成类东西有各类情景

python自带多态:

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

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

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

    9、属性援引(类名.属性)

              2、世袭的两用:                

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

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

    def 方法名(self):
        pass

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

 

               setattr:给指标的性子赋值,若属性空中楼阁,先创立后赋值

               delattr:删除该对象内定的叁个属性

整合指的是,在一个类中以此外三个类的对象作为数据属性,称为类的组

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


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

  

   
10、例化:类名加括号正是实例化,会活动触发__init__函数的运维,能够用它来为每种实例定制本身的性状

 

   3、 类:具备相近特征的风流洒脱类东西(人、狗、孟加拉虎卡塔尔(英语:State of Qatar)

       d、内置方法:__del__

    8、类的二种效应:属性援引和实例化

     
 b、短处:大器晚成套流水生产线或许流程正是来减轻三个主题素材,代码正是牵一发而哈博罗内全身

           a、继承

             
getattr:获取对象的性质或然措施,要是存在则打字与印刷出来。hasattr和getattr配套使用

__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中,默认是有的

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

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

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

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

抽象类和接口类的使用:

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

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

 

   1、面向进程

         
 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

   2、面向对象

     
 b、劣势:可控性差,无法向面向进程的前后相继设计流水生产线式的能够很精准的预测难题的管理流程与结果,面向对象的主次风度翩翩旦在这里早先就有对象时期的人机联作消灭难题。

              1、世袭的语法

                  1、优点:

发表评论

电子邮件地址不会被公开。 必填项已用*标注