Python中, 仿照经典代码实现单例, 却出现了不是单例的的状态, 代码哪里出错了 ?
巴扎黑
巴扎黑 2017-04-18 10:24:53
0
1
591

实际现象

  • 期望实现单例, 保持某个属性全局唯一

预期现象

  • 仿照经典实现代码, 却出现了不是单例的情况

我要做什么

  • 实现scheduler全局唯一, 不派生过多的scheduler

重现步骤

  1. 拷贝代码

  2. 运行之

  3. 查看内存地址

相关代码

  • 仿照经典实现

from apscheduler.schedulers.background import BackgroundScheduler

class Borg(object):
    

    __shared_state = {}

    def __init__(self):
        self.__dict__ = Borg.__shared_state

        self.scheduler = BackgroundScheduler()
        
        
s1 = Borg().scheduler
s2 = Borg().scheduler

print s1, s2


# <apscheduler.schedulers.background.BackgroundScheduler object at 0x02623DF0> 
# <apscheduler.schedulers.background.BackgroundScheduler object at 0x02D801D0>
  • 我自己想的办法

from apscheduler.schedulers.background import BackgroundScheduler


class Borg(object):
    @classmethod
    def get_scheduler(cls):
        try:
            cls_scheduler = cls.scheduler
        except AttributeError as e:
            cls.scheduler = BackgroundScheduler()

            return cls.scheduler
        else:
            return cls_scheduler
        




bs1 = 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__共享的類別屬性__shared_state的字典,後面建立的實例會覆寫前面實例的__dict__

s1 = Borg().scheduler
s2 = Borg().scheduler

建立一個實例s1,同时初始化属性scheduler,此时的地址是0x02623DF0,再创建一个实例s2,然后修改了属性scheduler,地址为0x02D801D0s1s2其實是兩個不同實例,只不過他們的屬性共用類別屬性,看起來就像單例的效果。

如果把程式碼改成這樣,應該就能看得更清楚過程:

s1 = Borg()
print(s1.scheduler)
s2 = Borg()
print(s1.scheduler)
print(s2.scheduler)
print(s1.scheduler is s2.scheduler)
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板