Python编程:面向对象深入

简介: Python编程:面向对象深入

基础知识

编程:语法+数据结构+算法


编程范式:

面向过程,step by step top-down language

面向对象oop,世界万物,皆可分类,皆为对象


特性

class –实例化–> object

实例化:把类变成具体对象的过程


封装:数据隐藏

把一些功能的实现细节不对外暴露


继承:代码复用

组合

单继承

多继承

py2

- 经典类:深度优先来继承的

- 新式类:广度优先来继承的 class Foo(object)

py3

- 经典类和新式类都是按照广度优先来继承的


多态:接口重用

一个接口,多种实现


类:

1. 属性:

1. 类变量 大家共用属性,节省内存开销

2. 实例变量(静态属性):作用域是实例本身

3. 私有属性 __开头


2.方法(动态属性)

1. 构造函数:init 实例化时做类的初始化工作

2. 析构函数:del 释放,销毁对象时执行,通常用于收尾工作,如关闭数据库连接,关闭临时文件

3. 私有方法 __开头

4. 静态方法:staticmethod与类没什么关系,只是名义上数据

5. 类方法:classmethod 只能访问类变量,不能访问实例变量

6. 属性方法:property 把一个方法变成一个静态属性


编程原则:

1、不写重复代码

2、代码会经常变更,做到易读,易改


对象实例化:

数据拷贝

方法不拷贝

object.method 相当于 class.method(object)


类属性

class Dog(object):
    count = 0  # 类变量
    lst = []
    def __init__(self, name): # 构造函数
        self.name = name  # 实例变量
        self.__age = 0  # 私有属性
    def bark(self):  # 方法
        print("%s bark" % self.name)
    def __del__(self):  # 析构函数
        print("%s del" % self.name)
# 实例化对象,并赋予实例变量,相当于局部变量
d1 = Dog("Tom")
d2 = Dog("Alex")
d3 = Dog("Jack")
# 调用对象方法
d1.bark()   # Tom bark
d2.bark()   # Alex bark
d3.bark()   # Jack bark
# 修改类变量,相当于全局变量
d1.count = 12
d2.count = 12
d3.count = 12
print(Dog.count)   #0  #类变量 没有被修改
print(d1.count)    #12
print(d1.count)    #12
print(d1.count)    #12
d1.lst.append("d1")
d2.lst.append("d2")
d3.lst.append("d3")
# 类变量 列表被修改了
print(Dog.lst)   # ['d1', 'd2', 'd3']
print(d1.lst)    # ['d1', 'd2', 'd3']
print(d2.lst)    # ['d1', 'd2', 'd3']
print(d3.lst)    # ['d1', 'd2', 'd3']

多态

class Animal(object):
    count = 1
    def __init__(self, name):
        self.name = name
        self.__color = None
    def talk(self):
        pass
    @staticmethod  # 静态方法
    def animal_talk(animal):
        animal.talk()
    @classmethod  # 类方法
    def animal_sleep(cls):
        print(cls,cls.count)
    @property  # 属性方法
    def color(self):
        return  self.__color
    @color.setter  # 设置
    def color(self, color):
        self.__color = color
    @color.deleter  # 删除
    def color(self):
        del self.__color
class Cat(Animal):
    def talk(self):
        print("%s talking" % self.name)
class Dog(Animal):
    def talk(self):
        print("%s talking" % self.name)
cat = Cat("mimi")
dog = Dog("jiji")
Animal.animal_talk(cat)
Animal.animal_talk(dog)
Animal.animal_sleep()
print(dog.color)
dog.color = "red"
print(dog.color)
del dog.color

继承

# class People: #经典类
class People(object): # 新式类
    def __init__(self, name, age):
        self.name = name
        self.age = age
    def sleep(self):
        print("%s is sleeping" % self.name)
class Animal(object):
    def drink(self):
        print("%s drinking" % self.name)
class Man(People, Animal): # 多继承
    def __init__(self, name, age, money):
        People.__init__(self, name, age)
        # 等价于:super(Man, self).__init__(name, age) 新式类写法
        self.money = money
        print("%s have money %s" % (name, money))
    def work(self):
        print("%s is working" % self.name)
    def sleep(self):  # 重载父类方法
        People.sleep(self)  # 调用父类方法
        print("Man is sleeping")
class Woman(People):
    def eat(self):
        print("%s is eating" % self.name)
m = Man("Tom", 23, 2000)
w = Woman("Jack", 24)
m.sleep()  # Tom is sleeping
m.work()  # Tom is working
w.sleep()  # Jack is sleeping
w.eat()  # Jack is eating
m.drink() # Tom drinking

继承顺序

class A(object):
    pass
    # def __init__(self):
    #     print("init A")
class B(object):
    def __init__(self):
        print("init B")
class C(A):
    pass
    # def __init__(self):
    #     print("init C")
class D(B):
    pass
    # def __init__(self):
    #     print("init D")
class E(C, D):
    pass
    # def __init__(self):
    #     print("init E")
e = E()
# C -> A -> D -> B

类的特殊方法


class Dog(object):
    """类的描述信息"""
    def __init__(self,name):
        self.name = name
        self.data = {}
    def __call__(self):
        print("call")
    def __str__(self):  #打印时触发
        return self.name
    def __getitem__(self, item): # 像字典一样访问对象
        print("getitem")
        return self.data.get(item)
    def __setitem__(self, key, value):  # 设置值
        print("setitem")
        self.data[key] = value
    def __delitem__(self, key):  # 删除值
        print("delitem")
        del self.data[key]
print(Dog.__doc__) # 输出类的描述信息
dog = Dog("Tom")
print(dog.__module__)  # 输出模块  __main__
print(dog.__class__)  # 输出类  <class '__main__.Dog'>
dog()  # 对象() 括号触发__call__ 方法
print(Dog.__dict__)  #打印类所有属性,不包括实例属性
# {'__weakref__': <attribute '__weakref__' of 'Dog' objects>,
# '__dict__': <attribute '__dict__' of 'Dog' objects>,
# '__init__': <function Dog.__init__ at 0x00000000047B5BF8>,
# '__doc__': '类的描述信息',
# '__call__': <function Dog.__call__ at 0x00000000047B5C80>,
# '__module__': '__main__'}
print(dog.__dict__)  # 打印实例所有属性,不包括类属性
# {'name': 'Tom'}
print(dog)
dog["dog1"] = "dogA"
dog["dog2"] = "dogB"
dog["dog3"] = "dogC"
print(dog["dog1"])
print(dog["dog2"])
print(dog["dog3"])
print(dog.data)
del dog["dog1"]
del dog["dog2"]
del dog["dog3"]
print(dog.data)

类的本质


# python一切皆为对象,类类型也是对象 ,由type类实例化而来
# class Foo():
#     def __init__(self, name, age):
#         self.name = name
#         self.age = age
#
#     def talk(self):
#         print("%s is talking" % self.name)
#
# f= Foo("Alex", 23)
# f.talk()
# 等价于:
def __init__(self, name, age):
    self.name = name
    self.age = age
def talk(self):
    print("%s is talking" % self.name)
Foo = type("Foo", (object,), {"__init__": __init__, "talk": talk})
f= Foo("Alex", 23)
f.talk()

元类

class Foo(object):
    def __init__(self, name):
        self.name = name
        print("init")
    def __new__(cls, *args, **kwargs):
        print("new")
        return object.__new__(cls)  # 继承父类的 new 方法
f = Foo("Tom")
# new
# init
# 元类metaclass:就是类的类,所有类都源自type
print(f.__class__)  # <class '__main__.Foo'>
print(Foo.__class__)  # <class 'type'>
a = 5
print(a.__class__)  #<class 'int'>
print(a.__class__.__class__)  #<class 'type'>
b = "name"
print(b.__class__)  # <class 'str'>
print(b.__class__.__class__)  # <class 'type'>
def foo(): pass
print(foo.__class__)  #<class 'function'>
print(foo.__class__.__class__)  #<class 'type'>

反射

# 反射函数
"""
hasattr() 检查成员
getattr() 获取成员
setattr() 设置成员
delattr() 删除成员
"""
class Foo(object):
    def __init__(self):
        self.name = "Tom"
    def eat(self):
        print("eating")
def talk():
    print("talking")
f= Foo()
choice = input("输入>>")
if hasattr(f, choice):  # 判断对象是否有名称为choice 的属性
    delattr(f, choice)   # 删除对象属性
    # func = getattr(f, choice)  # 通过字符串获取对象函数地址
    # func()
else:
    setattr(f, "talk", talk)  # 动态给对象增加新方法
    f.talk()
    setattr(f, "age", 23)  #给对象增加静态属性
    print(f.age)
print(f.name)

参考文章:


全面深入理解 Python 面向对象

相关文章
|
3月前
|
数据采集 机器学习/深度学习 人工智能
Python:现代编程的首选语言
Python:现代编程的首选语言
319 102
|
3月前
|
数据采集 机器学习/深度学习 算法框架/工具
Python:现代编程的瑞士军刀
Python:现代编程的瑞士军刀
345 104
|
3月前
|
人工智能 自然语言处理 算法框架/工具
Python:现代编程的首选语言
Python:现代编程的首选语言
276 103
|
3月前
|
机器学习/深度学习 人工智能 数据挖掘
Python:现代编程的首选语言
Python:现代编程的首选语言
206 82
|
2月前
|
Python
Python编程:运算符详解
本文全面详解Python各类运算符,涵盖算术、比较、逻辑、赋值、位、身份、成员运算符及优先级规则,结合实例代码与运行结果,助你深入掌握Python运算符的使用方法与应用场景。
219 3
|
2月前
|
数据处理 Python
Python编程:类型转换与输入输出
本教程介绍Python中输入输出与类型转换的基础知识,涵盖input()和print()的使用,int()、float()等类型转换方法,并通过综合示例演示数据处理、错误处理及格式化输出,助你掌握核心编程技能。
483 3
|
2月前
|
并行计算 安全 计算机视觉
Python多进程编程:用multiprocessing突破GIL限制
Python中GIL限制多线程性能,尤其在CPU密集型任务中。`multiprocessing`模块通过创建独立进程,绕过GIL,实现真正的并行计算。它支持进程池、队列、管道、共享内存和同步机制,适用于科学计算、图像处理等场景。相比多线程,多进程更适合利用多核优势,虽有较高内存开销,但能显著提升性能。合理使用进程池与通信机制,可最大化效率。
300 3
|
2月前
|
Java 调度 数据库
Python threading模块:多线程编程的实战指南
本文深入讲解Python多线程编程,涵盖threading模块的核心用法:线程创建、生命周期、同步机制(锁、信号量、条件变量)、线程通信(队列)、守护线程与线程池应用。结合实战案例,如多线程下载器,帮助开发者提升程序并发性能,适用于I/O密集型任务处理。
312 0
|
3月前
|
数据采集 机器学习/深度学习 人工智能
Python:现代编程的多面手
Python:现代编程的多面手
93 0
|
3月前
|
存储 人工智能 算法
Python实现简易成语接龙小游戏:从零开始的趣味编程实践
本项目将中国传统文化与编程思维相结合,通过Python实现成语接龙游戏,涵盖数据结构、算法设计与简单AI逻辑,帮助学习者在趣味实践中掌握编程技能。
398 0

推荐镜像

更多