博客
关于我
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 Timestamp时间隔了8小时
查看>>
Mysql tinyint(1)与tinyint(4)的区别
查看>>
mysql union orderby 无效
查看>>
mysql v$session_Oracle 进程查看v$session
查看>>
mysql where中如何判断不为空
查看>>
MySQL Workbench 使用手册:从入门到精通
查看>>
mysql workbench6.3.5_MySQL Workbench
查看>>
MySQL Workbench安装教程以及菜单汉化
查看>>
MySQL Xtrabackup 安装、备份、恢复
查看>>
mysql [Err] 1436 - Thread stack overrun: 129464 bytes used of a 286720 byte stack, and 160000 bytes
查看>>
MySQL _ MySQL常用操作
查看>>
MySQL – 导出数据成csv
查看>>
MySQL —— 在CentOS9下安装MySQL
查看>>
MySQL —— 视图
查看>>
mysql 不区分大小写
查看>>
mysql 两列互转
查看>>
MySQL 中开启二进制日志(Binlog)
查看>>
MySQL 中文问题
查看>>
MySQL 中日志的面试题总结
查看>>
mysql 中的all,5分钟了解MySQL5.7中union all用法的黑科技
查看>>