不做大哥好多年 不做大哥好多年
首页
  • MySQL
  • Redis
  • Elasticsearch
  • Kafka
  • Etcd
  • MongoDB
  • TiDB
  • RabbitMQ
  • 01.GO基础
  • 02.面向对象
  • 03.并发编程
  • 04.常用库
  • 05.数据库操作
  • 06.Beego框架
  • 07.Beego商城
  • 08.GIN框架
  • 09.GIN论坛
  • 10.微服务
  • 01.Python基础
  • 02.Python模块
  • 03.Django
  • 04.Flask
  • 05.SYL
  • 06.Celery
  • 10.微服务
  • 01.Java基础
  • 02.面向对象
  • 03.Java进阶
  • 04.Web基础
  • 05.Spring框架
  • 100.微服务
  • Docker
  • K8S
  • 容器原理
  • Istio
  • 数据结构
  • 算法基础
  • 算法题分类
  • 前置知识
  • PyTorch
  • 01.Python
  • 02.GO
  • 03.Java
  • 04.业务问题
  • 05.关键技术
  • 06.项目常识
  • 10.计算机基础
  • Linux基础
  • Linux高级
  • Nginx
  • KeepAlive
  • ansible
  • zabbix
  • Shell
  • Linux内核

逍遥子

不做大哥好多年
首页
  • MySQL
  • Redis
  • Elasticsearch
  • Kafka
  • Etcd
  • MongoDB
  • TiDB
  • RabbitMQ
  • 01.GO基础
  • 02.面向对象
  • 03.并发编程
  • 04.常用库
  • 05.数据库操作
  • 06.Beego框架
  • 07.Beego商城
  • 08.GIN框架
  • 09.GIN论坛
  • 10.微服务
  • 01.Python基础
  • 02.Python模块
  • 03.Django
  • 04.Flask
  • 05.SYL
  • 06.Celery
  • 10.微服务
  • 01.Java基础
  • 02.面向对象
  • 03.Java进阶
  • 04.Web基础
  • 05.Spring框架
  • 100.微服务
  • Docker
  • K8S
  • 容器原理
  • Istio
  • 数据结构
  • 算法基础
  • 算法题分类
  • 前置知识
  • PyTorch
  • 01.Python
  • 02.GO
  • 03.Java
  • 04.业务问题
  • 05.关键技术
  • 06.项目常识
  • 10.计算机基础
  • Linux基础
  • Linux高级
  • Nginx
  • KeepAlive
  • ansible
  • zabbix
  • Shell
  • Linux内核
  • Python

    • 01.进程
    • 02.线程
    • 03.协程
    • 04.select、poll、epoll
    • 05.装饰器
    • 06.生成器和迭代器
    • 07.面向对象
      • 01.面向对象
        • 1.1 什么是面向对象?(What)
        • 1.2 封装、继承、多态?特性
        • 1.3 新式类&经典类
        • 1.4 静态方法、类方法、属性方法
        • 1.5 魔法方法
        • 1.6 反射
        • 1.7 单例模式
    • 08.深浅拷贝
    • 09.垃圾回收
    • 10.上下文管理
    • 11.高阶函数
    • 12.次重点
  • GO

  • Java

  • 业务问题

  • 关键技术

  • 项目常识

  • 计算机基础

  • 常识
  • Python
xiaonaiqiang
2021-02-09
目录

07.面向对象

# 01.面向对象

https://www.cnblogs.com/xiaonq/p/7880547.html#i7

# 1.1 什么是面向对象?(What)

  • 使用模板的思想,将世界完事万物使用对象来表示一个类型

# 1.2 封装、继承、多态?特性

  • 封装
    • 对类中属性和方法进行一种封装,隐藏了实现细节
  • 继承
    • 子类继承父类后,就具有了父类的所有属性和方法,先继承,后重写
    • 新式类深度优先、经典类广度优先
  • 多态
    • 一种接口,多种表现形式
    • 中国人、和美国人都能讲话,调用中国人的类讲中文,调用美国人将英文

# 1.3 新式类&经典类

  • pythn3无论新式类还是经典类都是用 广度优先
  • python2中,新式类:广度优先,经典类:深度优先

class D:
    def talk(self):
        print('D')

class B(D):
    pass
    # def talk(self):
    #     print('B')

class C(D):
    pass
    def talk(self):
        print('C')

class A(B,C):
    pass
    # def talk(self):
    #     print('A')

a = A()
a.talk()
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21

# 1.4 静态方法、类方法、属性方法

  • 静态方法
    • 特点:名义上归类管理,实际上不能访问类或者变量中的任意属性或者方法
    • 作用:让我们代码清晰,更好管理
    • 调用方式: 既可以被类直接调用,也可以通过实例调用
class Dog(object):
    def __init__(self,name):
        self.name = name
        
    @staticmethod
    def eat():
        print("I am a static method")
        
d = Dog("ChenRonghua")
d.eat()                       # 方法1:使用实例调用
Dog.eat()                     # 方法2:使用类直接调用
1
2
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调用
1
2
3
4
5
6
7
8
9
10
11
  • 属性方法
    • 属性方法把一个方法变成一个属性,隐藏了实现细节,调用时不必加括号直接d.eat即可调用self.eat()方法
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
2
3
4
5
6
7
8
9
10
11

# 1.5 魔法方法

  • _new_
    • 产生一个实例
  • _init_
    • 产生一个对象
  • _del_
    • 析构方法,删除无用的内存对象(当程序结束会自动自行析构方法)

# 1.6 反射

  • hasattr: 判断当前类是否有这个方法
class Dog(object):
    def eat(self,food):
        print("eat method!!!")
d = Dog()

#hasattr判断对象d是否有eat方法,有返回True,没有返回False
print(hasattr(d,'eat'))     #True
print(hasattr(d,'cat'))     #False
1
2
3
4
5
6
7
8
  • getattr: 通过字符串反射出这个方法的内存地址
class Dog(object):
    def eat(self):
        print("eat method!!!")
d = Dog()

if hasattr(d,'eat'):          # hasattr判断实例是否有eat方法
    func = getattr(d, 'eat')  # getattr获取实例d的eat方法内存地址
    func()                    # 执行实例d的eat方法
#运行结果:  eat method!!!
1
2
3
4
5
6
7
8
9
  • setattr:将当前类添加一个方法
  • delatrr: 删除实例属性

# 1.7 单例模式

  • 单例模式:永远用一个对象得实例,避免新建太多实例浪费资源
  • 实质:使用__new__方法新建类对象时先判断是否已经建立过,如果建过就使用已有的对象
  • 使用场景:如果每个对象内部封装的值都相同就可以用单例模式
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()       # obj1和obj2获取的就是__new__方法返回的内容
obj2 = Foo()
print(obj1,obj2)   # 运行结果: <__main__.Foo object at 0x00D3B450>    <__main__.Foo object at 0x00D3B450>

# 运行结果说明:
# 这可以看到我们新建的两个Foo()对象内存地址相同,说明使用的•同一个类,没有重复建立类
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
上次更新: 2025/2/25 11:09:45
06.生成器和迭代器
08.深浅拷贝

← 06.生成器和迭代器 08.深浅拷贝→

最近更新
01
04.数组双指针排序_子数组
03-25
02
08.动态规划
03-25
03
06.回溯算法
03-25
更多文章>
Theme by Vdoing | Copyright © 2019-2025 逍遥子 技术博客 京ICP备2021005373号
  • 跟随系统
  • 浅色模式
  • 深色模式
  • 阅读模式