小白一枚,按教程里代码运行,同一个函数在python2和Python3不同版本写在一起,下面的运行结果,能算出错?!对这种写法不是不理解
# -*- 单例实现方法三:元类 -*-#
#元类是用于创建类对象的类,类对象创建实例对象时一定要调用call方法,因此在
#调用call时候保证始终只创建一个实例即可,type是python的元
# -*- 单例实现方法三:元类 -*-#
#元类是用于创建类对象的类,类对象创建实例对象时一定要调用call方法,因此在
#调用call时候保证始终只创建一个实例即可,type是python的元类
class Singleton1(type):
def __call__(cls,*args,**kwargs):
if not hasattr(cls,'_instance'):
cls._instance=super(Singleton1,cls).__call__(*args,**kwargs)
return cls._instance
#python2
class Foo(object):
__metaclass__=Singleton1
print('python2')
#python3
class Foo(metaclass=Singleton1):
print('python3')
f3 = Foo()
f4 = Foo()
print(f3 is f4)
运行结果如下:
python2
python3
True
这篇博客讨论了在Python2和Python3中使用元类实现单例模式的方法。代码示例展示了如何创建一个确保无论调用多少次,只会生成一个实例的Singleton1元类。在Python2中通过`__metaclass__`关键字定义元类,在Python3中则使用`metaclass`语法。运行结果显示,无论在哪个版本中,`f3`和`f4`都是同一个实例,验证了单例模式的正确性。
71万+

被折叠的 条评论
为什么被折叠?



