博客
关于我
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/

你可能感兴趣的文章
MySQL8修改密码的方法
查看>>
Mysql8在Centos上安装后忘记root密码如何重新设置
查看>>
Mysql8在Windows上离线安装时忘记root密码
查看>>
MySQL8找不到my.ini配置文件以及报sql_mode=only_full_group_by解决方案
查看>>
mysql8的安装与卸载
查看>>
MySQL8,体验不一样的安装方式!
查看>>
MySQL: Host '127.0.0.1' is not allowed to connect to this MySQL server
查看>>
Mysql: 对换(替换)两条记录的同一个字段值
查看>>
mysql:Can‘t connect to local MySQL server through socket ‘/var/run/mysqld/mysqld.sock‘解决方法
查看>>
MYSQL:基础——3N范式的表结构设计
查看>>
MYSQL:基础——触发器
查看>>
Mysql:连接报错“closing inbound before receiving peer‘s close_notify”
查看>>
mysqlbinlog报错unknown variable ‘default-character-set=utf8mb4‘
查看>>
mysqldump 参数--lock-tables浅析
查看>>
mysqldump 导出中文乱码
查看>>
mysqldump 导出数据库中每张表的前n条
查看>>
mysqldump: Got error: 1044: Access denied for user ‘xx’@’xx’ to database ‘xx’ when using LOCK TABLES
查看>>
Mysqldump参数大全(参数来源于mysql5.5.19源码)
查看>>
mysqldump备份时忽略某些表
查看>>
mysqldump实现数据备份及灾难恢复
查看>>