Python中, 仿照经典代码实现单例, 却出现了不是单例的的状态, 代码哪里出错了 ?
问题描述
实际现象期望实现单例, 保持某个属性全局唯一
预期现象仿照经典实现代码, 却出现了不是单例的情况
我要做什么实现scheduler全局唯一, 不派生过多的scheduler
重现步骤拷贝代码
运行之
查看内存地址
相关代码仿照经典实现
from apscheduler.schedulers.background import BackgroundSchedulerclass Borg(object):__shared_state = {} def __init__(self):self.__dict__ = Borg.__shared_stateself.scheduler = BackgroundScheduler()s1 = Borg().schedulers2 = Borg().schedulerprint s1, s2# <apscheduler.schedulers.background.BackgroundScheduler object at 0x02623DF0> # <apscheduler.schedulers.background.BackgroundScheduler object at 0x02D801D0>
我自己想的办法
from apscheduler.schedulers.background import BackgroundSchedulerclass Borg(object): @classmethod def get_scheduler(cls):try: cls_scheduler = cls.schedulerexcept AttributeError as e: cls.scheduler = BackgroundScheduler() return cls.schedulerelse: return cls_schedulerbs1 = Borg.get_scheduler()bs2 = Borg.get_scheduler()bs3 = Borg.get_scheduler()print bs1, bs2, bs3# <apscheduler.schedulers.background.BackgroundScheduler object at 0x02752D70> # <apscheduler.schedulers.background.BackgroundScheduler object at 0x02752D70> # <apscheduler.schedulers.background.BackgroundScheduler object at 0x02752D70>上下文环境
产品版本: Python 2.7 APScheduler最新
操作系统: Linux
Github链接, 经典实现: https://github.com/faif/pytho...
问题解答
回答1:经典例子这个不能算是纯单例,而是具有单例特性的Brog模式。
其魔法在于利用类Brog共享的类属性__shared_state的字典,后面创建的实例会覆盖前面实例的__dict__。
s1 = Borg().schedulers2 = Borg().scheduler
创建一个实例s1,同时初始化属性scheduler,此时的地址是0x02623DF0,再创建一个实例s2,然后修改了属性scheduler,地址为0x02D801D0。s1和s2其实是两个不同实例,只不过他们的属性共用类属性,看起来就像单例的效果。
如果把代码改成这样,应该就能看得更清楚过程:
s1 = Borg()print(s1.scheduler)s2 = Borg()print(s1.scheduler)print(s2.scheduler)print(s1.scheduler is s2.scheduler)
相关文章:
1. Python中的内列表问题,真的很困惑2. 为什么python中实例检查推荐使用isinstance而不是type?3. python3.x - python中的虚拟环境怎样设置一直处于激活状态4. python中的 + 不能和java一样作为连接符么?5. json - python中用正则表达式去掉字符串中的冒号6. python中子类父类继承具体指什么 是指第二个类的参数是第一个类吗,加于不加有什么区别呢7. 小白,不知道如何解决keras在python中导入失败?8. python pymysql 执行比较时间的sql语句,在mysql中可以顺了执行,但是在python中执行为何报错?9. Python中使用超长的List导致内存占用过大10. python中开发中比如道具之类的配置文件,是以什么文件格式存储
