Python面向对象总结

#------面向对象------#
(1)什么时候用面向对象
----答:1.代码量大,功能多。2.处理比较复杂角色之间的关系

#------创建一个对象------#
类名()  实例化
__new__()创造了一个对象的空间,还可以做一些简单的初始化。

#------创建一个类-------#
class Leiming  语法级别,Python解释器读到就会创建一个类
type 是所有类的元类,object 是所有类的父类
类也是被创建出来的,type 创建的,我们可以指定元类 metaclass,默认是type
class A(metaclass = type):pass
type(类名) = type ,那么type就是这个类的元类。

from abc import ABCMeta, abstractmethod
class Payment(metaclass=ABCMeta):pass

上面这个抽象类的元类就是abc.ABCMeta

#---------类---------#




#---------对象---------#

类创造对象的过程就是实例化的过程:构造函数 __new__() 初始化函数 __init__()
可以通过指针(引用)找到类的空间中的内容
对象本身内部也存储了一些属于对象的属性


#---------组合------———#

一个类的对象作为另一个类对象的属性

#--------继承---------#
经典类:python2中默认类,如果继承object就是新式类
新式类:python3的类都为新式类,没有经典类

单继承和多继承
#---单继承---#
---如果子类的对象调用某个方法
------如果子类有:调用子类
---------子类有但想调用父类的:
------------super().方法名
------------类名.方法名
---如果子类没有找父类:
---一层一层往上找
#注:在任何类中调用的方法,都要自己分辨一下,这是谁的对象。


#---多继承-----#

新式类
----继承方法广度优先-C3算法,mro()可以产看继承顺序
----python3默认继承object,python2需要主动继承
----使用 super()方法,python3不需要传self和子类名,但是python2必须传

经典类
----继承方式深度优先,没有 mro()方法
----python2不继承object类,默认是经典类
----使用 super()方法,python3不需要传self和子类名,但是python2必须传


#---抽象类,接口类----#
#---多态,鸭子类型----#


#----封装,私有的----#
--广义的封装:把方法和属性都封装在一个类中,定义一个规矩来描述一类事物
--狭义的封装:私有化只能在类的内部访问
----__静态变量,私有方法,私有对象属性,私有类方法,私有静态方法
----在内存中的存储_类名__名字
----在子类中不可以访问父类的私有变量
----私有:不能在类外部使用也不能被继承

#---@property----#
装饰器函数,帮助我们将类中的方法伪装成为属性
调用方法时不用加 () 返回值找出
@方法名.setter 装饰器  修改被property装饰的属性时,调用这个方法,有两个参数,self 被修改的值
@方法名.deleter 装饰器 当要删除被property装饰的属性时,会调用这个方法。

什么时候回用到呢?
答:当使用一个属性,但是对这个属性有约束的时候。

#----classmethod 类方法装饰器-----#
推荐使用类名调用,默认传类名为第一个参数
不用对象命名空间的内容,而用到了类命名空间中的变量(静态属性),或者类方法,或者静态方法

#----staticmethod 静态方法装饰器----#
如果一个类里面的方法,即不需要用到self中的资源,也不用到cls中的资源
相当于一个普通函数
但是由于某种原因,还要把这个方法放在类中,这个时候就将这个方法变为静态方法,那么这里的某种原因是什么呢?
----答:1,完全想用面向对象编程,所有的函数都必须写在类里面
-------2,某个功能确确实实是这个类的方法,但是确确实实没有用到和这个类有关系的资源

#--------反射-------#
以某个指定的命名空间中,用字符串数据类型的变量名来获取变量的值
应用场景:
1,类名,反射 静态属性,类方法,静态方法
2,对象,反射 对象属性,方法
3,模块, 反射 模块中的方法
4.自己模块中

 1.getattr
    用法:getattr(object, name[,default]) -> value
    返回object中name字符串对应的方法和属性,不存在返回默认值default。
    如果没有传default,那么找不到就会报错
 2.hasattr
    用法:hasattr(object, name) #判断object中有没有一个name字符串对应的方法和属性
                                #如果存在返回True,不存在返回False,一般与getattr配合使用

 3.setattr
    用法:setattr(object, name, value)
    修改object中name字符串对应的属性name变为value
 4.delattr
    用法:delattr(object, name)
    删除object中name字符串对应的属性和方法                 
用反射的必要条件:变量名只能拿到一个字符串  1,从文件中拿 2,交互拿input/网络传输

#------内置方法、魔法方法,双下方法-----#
__名字__不是被直接调用的
间接调用,内置方法、面向对象中特殊语法,Python提供的语法糖
原文地址:https://www.cnblogs.com/xiao-xue-di/p/9404196.html