0
点赞
收藏
分享

微信扫一扫

Python基础之——15_面向对象高级特性

诗与泡面 2022-05-04 阅读 73
python

目录

一、类属性与实例属性

二、类方法与静态方法

1、什么是类方法

2、什么是静态方法

三、property类属性

1、什么是property属性?

2、什么是类属性

四、单例模式

1、什么是单例模式

 2、为什么要用单例模式

3、如何实现单例模式

五、实验操作

5.1 类方法和实例方法

5.2 类方法和静态方法理解的简单案例

5.3 property类属性

5.4 property简单案例

5.5 理解单例模式

5.6 基于装饰器实现单例模式

5.7 基于new方法实现的单例模式

5.8 总结


一、类属性与实例属性

二、类方法与静态方法

1、什么是类方法

2、什么是静态方法

三、property类属性

1、什么是property属性?

2、什么是类属性

四、单例模式

1、什么是单例模式

 2、为什么要用单例模式

3、如何实现单例模式

五、实验操作

5.1 类方法和实例方法

"""
相关的源码:from datetime import  datetime
"""


class Student(object):
    def __init__(self, name, age):
        self.name = name
        self.age = age

    # 实例方法, python解释器会自动将对象/实例传入方法。
    def get_age(self):
        print('self:', self)
        return self.age

    # 类方法:python解释器会自动将类传入方法。
    @classmethod
    def get_cls(cls):
        print('cls:', cls)

    # 静态方法:python解释器不会自动传入任何参数
    @staticmethod
    def get_info():
        print("static method信息")


if __name__ == '__main__':
    s = Student('张三', 18)
    s.get_age()
    s.get_cls()
    s.get_info()

5.2 类方法和静态方法理解的简单案例

class date(object):
    # 正常的方法: 将对象作为参数传给self
    def get_self(self):
        print('self:', self)

    # 类方法: 将类名作为参数传给cls
    @classmethod
    def get_cls(cls):
        print('cls:', cls)

    # 静态方法:不自动传递任何参数
    @staticmethod
    def get_static(name, age):
        print("静态方法", name, age)


d = date()
d.get_self()
d.get_cls()
d.get_static("张三", 18)

5.3 property类属性

"""
类属性应用需求: 对于京东商城中显示电脑主机的列表页面,每次请求不可能把数据库中的所有内容都显示到页面上,而是通过分页的功能局部显示,所以在向数据库中请求数据时就要显示的指定获取从第m条到第n条的所有数据 这个分页的功能包括:
- 根据用户请求的当前页和总数据条数计算出 m 和 n
- 根据m 和 n 去数据库中请求数据

from datetime import  datetime
"""

class Page(object):
    """
    [user1, user2, user3......user100]
    page=2, per_page=10
    第一页: start=0 end=10
    第二页: start=10 end=20
    第三页: start=20 end=30
    ....
    第page页: start=(page-1)*per_page end=page*per_page
    """
    def __init__(self, page, per_page=10):
        self.page = page
        self.per_page = per_page

    # 类属性: 将类方法变成类属性的过程。
    @property
    def start(self):
        return (self.page-1) * self.per_page

    @property
    def end(self):
        return  self.page * self.per_page

if __name__ == '__main__':
    goods = ['good'+str(i+1) for i in range(100)]
    page = Page(page=10, per_page=3)
    print(goods[page.start:page.end])

5.4 property简单案例

 # 将类方法object.year()转变成类属性object.year, 只是让代码更加简洁而已。

class date(object):
    def __init__(self, year, month, day):
        # 私有属性
        self.__year = year
        self.__month = month
        self.__day = day

    # 将类方法object.year()转变成类属性object.year, 只是让代码更加简洁而已。
    @property
    def year(self):
        return self.__year


today = date(2021, 2, 27)
print(today.year)

5.5 理解单例模式

"""
什么是单例模式?
一个类只能实例化一个对象的设计模式称为单例模式。
"""

class People(object):
    pass

p1 = People()  # object
p2 = People()  # object
print(p1, p2)  # 每个对象的内存地址不同,肯定不是单例模式

5.6 基于装饰器实现单例模式

from functools import  wraps
def singleton(cls):
    # 通过一个字典存储类和对象信息{"Class":"object"}
    instances = {}
    @wraps(cls)
    def wrapper(*args, **kwargs):
        # 为了保证单例模式, 判断该类是否已经实例化为对象
        # 1. 如果有对象,直接返回存在的对象
        # 2. 如果没有则实例化对象, 并存储类和对象到字典中, 最后返回对象
        if instances.get(cls):
            return instances.get(cls)
        object = cls(*args, **kwargs)
        instances[cls] = object
        return  object
    return  wrapper

@singleton
class People(object):
    pass


p1 = People()
p2 = People()
print(p1, p2)
print(p1 is p2)  # 判断是否为单例模式(p1和p2内存地址是否相同)

5.7 基于new方法实现的单例模式

class People(object):
    _instance = None
    def __new__(cls, *args, **kwargs):
        """创建对象之前执行的内容"""
        if cls._instance is None:
            cls._instance = object.__new__(cls)
        return  cls._instance

    def __init__(self):
        """在new方法之后执行, 将属性和对象封装在一起"""
        print("正在执行构造方法init......")

p1 = People()
p2 = People()
print(p1, p2)

5.8 总结

"""
面向对象:
    1. 三大特性
        封装(必须要掌握的):
            __new__: 在实例化对象之前执行的, 返回对象。
            __init__: 构造方法, 实例化对象时自动执行。 常用于将对象和属性绑定在一起。
            self: 实质上是对象。
        继承(最多知识点的):
            多继承算法: python3中广度优先算法。
            私有属性和私有方法
        多态(最简单的):

    2. 三大特性的应用
        1). 链表的封装(Leetcode第二题)
        2). 栈的封装
        3). 队列的封装
        4). 二叉树的封装与先序遍历

    3. 高级特性
        1). @classmethod和@staticmethod(类方法和静态方法)
        2). @property类属性
        3). 单例模式: 一个类只能实例化一个对象
            基于装饰器
            基于new方法



"""
举报

相关推荐

0 条评论