01.面向对象
https://www.cnblogs.com/xiaonq/p/7880547.html#i7
 1.1 什么是面向对象?(What)
- 使用模板的思想,将世界完事万物使用对象来表示一个类型
 1.2 封装、继承、多态?特性
- 封装
- 继承
- 子类继承父类后,就具有了父类的所有属性和方法,先继承,后重写
- 新式类深度优先、经典类广度优先
 
- 多态
- 一种接口,多种表现形式
- 中国人、和美国人都能讲话,调用中国人的类讲中文,调用美国人将英文
 
 1.3 新式类&经典类
- pythn3无论新式类还是经典类都是用 广度优先
- python2中,新式类:广度优先,经典类:深度优先
 
 
| 12
 3
 4
 5
 6
 7
 8
 9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 
 | class D:def talk(self):
 print('D')
 
 class B(D):
 pass
 
 
 
 class C(D):
 pass
 def talk(self):
 print('C')
 
 class A(B,C):
 pass
 
 
 
 a = A()
 a.talk()
 
 | 
 1.4 静态方法、类方法、属性方法
- 静态方法
- 特点:名义上归类管理,实际上不能访问类或者变量中的任意属性或者方法
- 作用:让我们代码清晰,更好管理
- 调用方式: 既可以被类直接调用,也可以通过实例调用
 
| 12
 3
 4
 5
 6
 7
 8
 9
 10
 11
 
 | class Dog(object):def __init__(self,name):
 self.name = name
 
 @staticmethod
 def eat():
 print("I am a static method")
 
 d = Dog("ChenRonghua")
 d.eat()
 Dog.eat()
 
 | 
- 类方法
- 作用**:无需实例化直接被类调用
- 特性:** 类方法只能访问类变量,不能访问实例变量
- 类方法使用场景:** 当我们还未创建实例,但是需要调用类中的方法
- 调用方式:** 既可以被类直接调用,也可以通过实例调用
 
| 12
 3
 4
 5
 6
 7
 8
 9
 10
 11
 
 | class Dog(object):name = '类变量'                  #在这里如果不定义类变量仅定义实例变量依然报错
 def __init__(self,name):
 self.name = '实例变量'
 self.name = name
 @classmethod
 def eat(self,food):
 print("%s is eating %s"%(self.name,food))
 Dog.eat('baozi')                   #方法1:使用类直接调用
 d = Dog("ChenRonghua")
 d.eat("包子")                     #方法2:使用实例d调用
 
 | 
- 属性方法
- 属性方法把一个方法变成一个属性,隐藏了实现细节,调用时不必加括号直接d.eat即可调用self.eat()方法
 
| 12
 3
 4
 5
 6
 7
 8
 9
 10
 11
 
 | class Dog(object):def __init__(self, name):
 self.name = name
 
 @property
 def eat(self):
 print(" %s is eating" % self.name)
 d = Dog("ChenRonghua")
 d.eat()
 # 调用会出以下错误, 说NoneType is not callable, 因为eat此时已经变成一个静态属性了,
 # 不是方法了, 想调用已经不需要加()号了,直接d.eat就可以了
 
 | 
 1.5 魔法方法
- _new_
- _init_
- _del_
- 析构方法,删除无用的内存对象(当程序结束会自动自行析构方法)
 
  
 1.6 反射
| 12
 3
 4
 5
 6
 7
 8
 
 | class Dog(object):def eat(self,food):
 print("eat method!!!")
 d = Dog()
 
 
 print(hasattr(d,'eat'))
 print(hasattr(d,'cat'))
 
 | 
- getattr: 通过字符串反射出这个方法的内存地址
| 12
 3
 4
 5
 6
 7
 8
 9
 
 | class Dog(object):def eat(self):
 print("eat method!!!")
 d = Dog()
 
 if hasattr(d,'eat'):
 func = getattr(d, 'eat')
 func()
 
 
 | 
- setattr:将当前类添加一个方法
- delatrr: 删除实例属性
 1.7 单例模式
- 单例模式:永远用一个对象得实例,避免新建太多实例浪费资源
- 实质:使用__new__方法新建类对象时先判断是否已经建立过,如果建过就使用已有的对象
- 使用场景:如果每个对象内部封装的值都相同就可以用单例模式
| 12
 3
 4
 5
 6
 7
 8
 9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 
 | class Foo(object):instance = None
 def __init__(self):
 self.name = 'alex'
 
 def __new__(cls, *args, **kwargs):
 if Foo.instance:
 return Foo.instance
 else:
 Foo.instance = object.__new__(cls,*args,**kwargs)
 return Foo.instance
 
 obj1 = Foo()
 obj2 = Foo()
 print(obj1,obj2)
 
 
 
 
 | 
__END__