#-*-

encoding=utf-8 -*-

print '----------------------方法1--------------------------'

#方法1,实现__new__方法

#并在将一个类的实例绑定到类变量_instance上,

#如果cls._instance为None说明该类还没有实例化过,实例化该类,并返回

#如果cls._instance不为None,直接返回cls._instance

class Singleton(object):

def __new__(cls, *args, **kw):

if not hasattr(cls, '_instance'):

orig = super(Singleton, cls)

cls._instance = orig.__new__(cls, *args, **kw)

return cls._instance

class MyClass(Singleton):

a = 1

one = MyClass()

two = MyClass()

two.a = 3

print one.a

#3

#one和two完全相同,可以用id(), ==, is检测

print id(one)

#29097904

print id(two)

#29097904

print one == two

#True

print one is two

#True

print '----------------------方法2--------------------------'

#方法2,共享属性;所谓单例就是所有引用(实例、对象)拥有相同的状态(属性)和行为(方法)

#同一个类的所有实例天然拥有相同的行为(方法),

#只需要保证同一个类的所有实例具有相同的状态(属性)即可

#所有实例共享属性的最简单最直接的方法就是__dict__属性指向(引用)同一个字典(dict)

#可参看:http://code.activestate.com/recipes/66531/

class Borg(object):

_state = {}

def __new__(cls, *args, **kw):

ob = super(Borg, cls).__new__(cls, *args, **kw)

ob.__dict__ = cls._state

return ob

class MyClass2(Borg):

a = 1

one = MyClass2()

two = MyClass2()

#one和two是两个不同的对象,id, ==, is对比结果可看出

two.a = 3

print one.a

#3

print id(one)

#28873680

print id(two)

#28873712

print one == two

#False

print one is two

#False

#但是one和two具有相同的(同一个__dict__属性),见:

print id(one.__dict__)

#30104000

print id(two.__dict__)

#30104000

print '----------------------方法3--------------------------'

#方法3:本质上是方法1的升级(或者说高级)版

#使用__metaclass__(元类)的高级python用法

class Singleton2(type):

def __init__(cls, name, bases, dict):

super(Singleton2, cls).__init__(name, bases, dict)

cls._instance = None

def __call__(cls, *args, **kw):

if cls._instance is None:

cls._instance = super(Singleton2, cls).__call__(*args, **kw)

return cls._instance

class MyClass3(object):

__metaclass__ = Singleton2

one = MyClass3()

two = MyClass3()

two.a = 3

print one.a

#3

print id(one)

#31495472

print id(two)

#31495472

print one == two

#True

print one is two

#True

print '----------------------方法4--------------------------'

#方法4:也是方法1的升级(高级)版本,

#使用装饰器(decorator),

#这是一种更pythonic,更elegant的方法,

#单例类本身根本不知道自己是单例的,因为他本身(自己的代码)并不是单例的

def singleton(cls, *args, **kw):

instances = {}

def _singleton():

if cls not in instances:

instances[cls] = cls(*args, **kw)

return instances[cls]

return _singleton

@singleton

class MyClass4(object):

a = 1

def __init__(self, x=0):

self.x = x

one = MyClass4()

two = MyClass4()

two.a = 3

print one.a

#3

print id(one)

#29660784

print id(two)

#29660784

print one == two

#True

print one is two

#True

one.x = 1

print one.x

#1

print two.x

#1

python中__new__的用法_python中的__init__ 、__new__、__call__小结及使用相关推荐

  1. python常用函数的用法_python中常用函数整理

    1.map map是python内置的高阶函数,它接收一个函数和一个列表,函数依次作用在列表的每个元素上,返回一个可迭代map对象. class map(object):""&qu ...

  2. python 字典定义日志用法_python中字典(Dictionary)用法实例详解

    本文实例讲述了python中字典(Dictionary)用法.分享给大家供大家参考.具体分析如下: 字典(Dictionary)是一种映射结构的数据类型,由无序的"键-值对"组成. ...

  3. python中max函数用法_Python中max函数用法实例分析

    Python中max函数用法实例分析 更新时间:2015年07月17日 15:45:09 作者:优雅先生 这篇文章主要介绍了Python中max函数用法,实例分析了Python中max函数的功能与使用 ...

  4. python中print的用法_Python中print函数简单使用总结

    Python中print函数简单使用总结 print函数是Python的入门,每一个学习python的人都绕不开这个函数,下面介绍一下这个函数的用法. 打开电脑,选择python软件,下面选择pyth ...

  5. python中lambda()的用法_python中lambda()的用法

    在C++11和C#中都有匿名函数的存在.下面看看在python中匿名函数的使用. 1.lambda只是一个表达式,函数体比def简单很多. 2.lambda的主体是一个表达式,而不是一个代码块.仅仅能 ...

  6. [转载] python里字典的用法_python中字典(Dictionary)用法实例详解

    参考链接: Python字典dictionary copy方法 本文实例讲述了python中字典(Dictionary)用法.分享给大家供大家参考.具体分析如下: 字典(Dictionary)是一种映 ...

  7. python中replace的用法_python中replace的用法是什么?

    python中replace的用法是什么? Python replace() 方法把字符串中的 old(旧字符串) 替换成 new(新字符串),如果指定第三个参数max,则替换不超过 max 次. r ...

  8. python中sleep函数用法_python中sleep函数用法实例分析

    本文实例讲述了python中sleep函数用法.分享给大家供大家参考.具体如下: Python中的sleep用来暂停线程执行,单位为秒 #------------------------------- ...

  9. python中sleep的用法_python中sleep函数用法实例分析

    本文实例讲述了python中sleep函数用法.分享给大家供大家参考.具体如下: Python中的sleep用来暂停线程执行,单位为秒 #------------------------------- ...

  10. python中random模块用法_Python中random模块用法实例分析

    本文实例讲述了Python中random模块用法.分享给大家供大家参考.具体如下: import random x = random.randint(1,4); y = random.choice([ ...

最新文章

  1. Python 爬取北京二手房数据,分析北漂族买得起房吗?(附完整源码)
  2. 清除应用程序所有缓存
  3. Vue常用特性——表单操作、表单域修饰符(number:转化为数值 ;trim:去掉开始和结尾的空格 ; lazy : 将input事件切换为change事件)||自定义指令|| 局部指令
  4. 罗斯蒙特电磁流量计8723说明书_罗斯蒙特8712和8732E电磁流量计变送器的功能规格...
  5. TensorFlow学习笔记(七)feeds操作
  6. 逐一应对 检修三类型视频会议常见问题
  7. 如何更改从Outlook发送的电子邮件中的“答复”地址
  8. PyCharm光标变粗的解决办法
  9. python编程最大值_python求最大值最小值方法总结
  10. 阿里研究员玄难:如何做电商中台
  11. 大数据创造智慧城市的未来之光!
  12. Django 创建随机验证码
  13. rtthread studio与正点原子apollo(9)--I2C设备之IO扩展
  14. 基于uFUN开发板和扩展板的联网校准时钟
  15. tf.gather_nd用法详解
  16. KLAY 2000-SAN-2-W-HT
  17. 强制卸载VS2013
  18. IEduChina2019北京国际教育展暨国际教育论坛即将来袭!
  19. JavaScript进阶-编程思想、构造函数的原型对象、对象原型、原型继承以及原型链
  20. 不花钱使用google keyword planner(关键字规化器)

热门文章

  1. 征途服务管理器显示不出启动服务器,征途服务器管理器连接数据库
  2. Codeforces 1077F2 Pictures with Kittens (hard version)(DP+单调队列优化)
  3. SAP 中 Webservice的发布和调用过程。
  4. 最简单的图文教程,几步完成Git的公私钥配置
  5. 跨域请求的常用方式及解释
  6. java 获取 正在执行的方法名
  7. Scala实现Mapreduce程序4-----数据去重
  8. 数据结构C语言版之线性表
  9. 关于javaswing做的游戏的一点小总结x
  10. Java基本数据类型总结(转)