博客
关于我
Python(25)-单例设计模式
阅读量:208 次
发布时间:2019-02-28

本文共 1738 字,大约阅读时间需要 5 分钟。

单例设计模式

本系列博文来自学习《Python基础视屏教程》笔记整理,视屏教程连接地址:http://yun.itheima.com/course/273.html

1.单例设计模式

设计模式:不同的问题使用不同的解决套路。学习设计模式,在遇到已经有的问题时就直接使用套路解题就行了。

单例设计模式的应用场景:

音乐播放器、回收站、打印机 这些对象都只有一份,只有唯一的一个存在

单例设计模式:目的,让类创建的对象,在系统中只有唯一的一个实例,每次执行**类名()**返回对象,内存地址是相同的。

2.__new__方法

两个下划线开头,两个下划线结尾的方法(内置方法),是object类内置的一个 静态方法 。利用类创建对象时,由__new__方法给新建的对象分配空间,并将对象的引用返回给解释器。解释器进一步将这个引用返回给方法的初始化方法中的self 参数,并调用初始化方法。

重写new方法–实现单例的目的

class MusicPlayer(object):    # 定义一个类属性,初始值为none 用于记录对象的引用    # 第一次调用时赋值,后来调用就直接返回第一次调用的就行    instance=None    def __new__(cls, *args, **kwargs):        # 1.判断类属性是否是空对象        if cls.instance is None:            # 调用父类的方法,为第一个对象分配空间            cls.instance=super().__new__(cls)        # 返回类属性保存的对象引用        return cls.instance    pass#创建多个对象player1=MusicPlayer()player2=MusicPlayer()print(player1)print(player2)

输出:

<main.MusicPlayer object at 0x7f130b3be470>

<main.MusicPlayer object at 0x7f130b3be470>

3.初始动作只执行一次

在上面代码中,虽然每次使用类创建对象都指向相同的引用,但是初始化方法却是每次创建对象都会被调用,所以能做的就是让每次自动执行的初始化方法中个初始化动作只执行一次。

class MusicPlayer(object):    # 定义一个类属性,初始值为none 用于记录对象的引用    # 第一次调用时赋值,后来调用就直接返回第一次调用的就行    instance=None    int_flag=False    def __new__(cls, *args, **kwargs):        # 1.判断类属性是否是空对象        if cls.instance is None:            # 调用父类的方法,为第一个对象分配空间            cls.instance=super().__new__(cls)        # 返回类属性保存的对象引用        return cls.instance    def __init__(self):        # 判断是否执行过初始化动作,        if MusicPlayer.int_flag :            return        # 没有执行过,执行初始化动作                        print("初始化方法执行啦")        # 修改类属性标记        MusicPlayer.int_flag=True#创建多个对象player1=MusicPlayer()player2=MusicPlayer()print(player1)print(player2)

输出

初始化方法执行啦

<main.MusicPlayer object at 0x7f4ea08da438>
<main.MusicPlayer object at 0x7f4ea08da438>

转载地址:http://uxps.baihongyu.com/

你可能感兴趣的文章
Mysql 事务知识点与优化建议
查看>>
Mysql 优化 or
查看>>
mysql 优化器 key_mysql – 选择*和查询优化器
查看>>
MySQL 优化:Explain 执行计划详解
查看>>
Mysql 会导致锁表的语法
查看>>
mysql 使用sql文件恢复数据库
查看>>
mysql 修改默认字符集为utf8
查看>>
Mysql 共享锁
查看>>
MySQL 内核深度优化
查看>>
mysql 内连接、自然连接、外连接的区别
查看>>
mysql 写入慢优化
查看>>
mysql 分组统计SQL语句
查看>>
Mysql 分页
查看>>
Mysql 分页语句 Limit原理
查看>>
MySql 创建函数 Error Code : 1418
查看>>
MySQL 创建新用户及授予权限的完整流程
查看>>
mysql 创建表,不能包含关键字values 以及 表id自增问题
查看>>
mysql 删除日志文件详解
查看>>
mysql 判断表字段是否存在,然后修改
查看>>
MySQL 到底能不能放到 Docker 里跑?
查看>>