python设计模式---创建型之单例模式
数据结构和算法是基本功,
设计模式是最佳实现。
作为程序员,必须有空了就练一练哈。
# coding = utf-8 """ # 经典单例 class Singleton: def __new__(cls): if not hasattr(cls, 'instance'): cls.instance = super(Singleton, cls).__new__(cls) return cls.instance s1 = Singleton() print('Object created', s1) s2 = Singleton() print('Object created', s2) # 单例模式中的懒汉式实例化 class Singleton: __instance = None def __init__(self): if not Singleton.__instance: print('__init__ method called...') else: print('Instance already created: ', self.get_instance()) @classmethod def get_instance(cls): if not cls.__instance: cls.__instance = Singleton() return cls.__instance s1 = Singleton() print("Object created ", Singleton.get_instance()) s2 = Singleton() # 通过__init__实现Monostate单态模式 class Borg: __shared_stat = {"1": "one"} def __init__(self): self.x = 1 self.__dict__ = self.__shared_stat pass b1 = Borg() b2 = Borg() b1.x = 4 print('Borg Object b1: ', b1) print('Borg Object b2: ', b2) print('Object State b1: ', b1.__dict__) print('Object State b2: ', b2.__dict__) # 通过__new__实现Monostate单态模式 class Borg: __shared_stat = {"1": "one"} def __new__(cls, *args, **kwargs): obj = super().__new__(cls, *args, **kwargs) obj.__dict__ = cls.__shared_stat return obj b1 = Borg() b2 = Borg() b1.x = 4 print('Borg Object b1: ', b1) print('Borg Object b2: ', b2) print('Object State b1: ', b1.__dict__) print('Object State b2: ', b2.__dict__) # 元类示例 class MyInt(type): def __call__(cls, *args, **kwargs): print('****Here is my int****', args) print('Now do whatever you want with this object...') return type.__call__(cls, *args, **kwargs) class int(metaclass=MyInt): def __init__(self, x, y): self.x = x self.y = y i = int(4, 5) # 基于元类的单例 class MetaSingleton(type): _instances = {} def __call__(cls, *args, **kwargs): if cls not in cls._instances: cls._instances[cls] = super().__call__(*args, **kwargs) return cls._instances[cls] class Logger(metaclass=MetaSingleton): pass logger1 = Logger() logger2 = Logger() print(logger1, logger2) # sqlite3数据库连接单例 import sqlite3 class MetaSingleton(type): _instances = {} def __call__(cls, *args, **kwargs): if cls not in cls._instances: cls._instances[cls] = super().__call__(*args, **kwargs) return cls._instances[cls] class Database(metaclass=MetaSingleton): connection = None cursor = None def connect(self): if self.connection is None: self.connection = sqlite3.connect('db.sqlite3') self.cursor = self.connection.cursor() return self.cursor db1 = Database().connect() db2 = Database().connect() print('Database Objects DB1', db1) print('Database Objects DB2', db2) """ # 监控服务器单例 class HealthCheck: _instance = None _servers = [] def __new__(cls, *args, **kwargs): print('====new====') if not cls._instance: cls._instance = super().__new__(cls, *args, **kwargs) print(cls._instance) print('=======cls._instance========', cls._instance) return cls._instance # def __init__(self): # print('====init====') # self._servers = [] def add_server(self): self._servers.append('Server 1') self._servers.append('Server 2') self._servers.append('Server 3') self._servers.append('Server 4') self._servers.append('Server 5') print(self._servers) def change_server(self): self._servers.pop() self._servers.append('Server 6') print(self._servers) def __len__(self): return len(self._servers) hc1 = HealthCheck() hc1.add_server() print('Schedule health check for server (1)...') for i in range(len(hc1)): print('Checking ', hc1._servers[i]) hc2 = HealthCheck() hc2.change_server() print('Schedule health check for server (2)...') for i in range(len(hc2)): print('Checking ', hc2._servers[i])
C:\Users\Sahara\.virtualenvs\test\Scripts\python.exe C:/Users/Sahara/PycharmProjects/test/python_search.py ====new==== <__main__.HealthCheck object at 0x00000000021E35F8> =======cls._instance======== <__main__.HealthCheck object at 0x00000000021E35F8> ['Server 1', 'Server 2', 'Server 3', 'Server 4', 'Server 5'] Schedule health check )... Checking Server Checking Server Checking Server Checking Server Checking Server ====new==== =======cls._instance======== <__main__.HealthCheck object at 0x00000000021E35F8> ['Server 1', 'Server 2', 'Server 3', 'Server 4', 'Server 6'] Schedule health check )... Checking Server Checking Server Checking Server Checking Server Checking Server Process finished with exit code
python设计模式---创建型之单例模式的更多相关文章
- Python设计模式 - 创建型 - 单例模式(Singleton) - 十种
对于很多开发人员来说,单例模式算是比较简单常用.也是最早接触的设计模式了,仔细研究起来单例模式似乎又不像看起来那么简单.我们知道单例模式适用于提供全局唯一访问点,频繁需要创建及销毁对象等场合,的确方便 ...
- 【python设计模式-创建型】工厂方法模式
工厂模式(Factory Pattern)是 Java 中最常用的设计模式之一.这种类型的设计模式属于创建型模式,它提供了一种创建对象的最佳方式. 在工厂模式中,我们在创建对象时不会对客户端暴露创建逻 ...
- python设计模式---创建型之工厂模式
# coding = utf-8 from abc import ABCMeta, abstractmethod # 简单工厂模式 class Animal(metaclass=ABCMeta): @ ...
- [Python编程实战] 第一章 python的创建型设计模式1.1抽象工厂模式
注:关乎对象的创建方式的设计模式就是“创建型设计模式”(creational design pattern) 1.1 抽象工厂模式 “抽象工厂模式”(Abstract Factory Pattern) ...
- 设计模式01 创建型模式 - 单例模式(Singleton Pattern)
参考 [1] 设计模式之:创建型设计模式(6种) | 博客园 [2] 单例模式的八种写法比较 | 博客园 单例模式(Singleton Pattern) 确保一个类有且仅有一个实例,并且为客户提供一 ...
- C# 设计模式·创建型模式
面试问到这个··答不出来就是没有架构能力···这里学习一下···面试的时候直接让我说出26种设计模式··当时就懵逼了··我记得好像之前看的时候是23种的 还有3个是啥的··· 这里先列出几种创建型模式 ...
- javaScript设计模式-创建型设计模式
我们大家一听到设计模式就感觉设计模式是一个高端的东西,到底什么是设计模式呢?其实设计模式也就是我们的前辈在写代码的时候遇到的问题,提出的解决方案,为了方便人与人之间的交流,取了个名字,叫做设计模式. ...
- java设计模式--创建型模式(一)
2016-04-24 10:10:34 创建型模式:工厂方法模式.抽象工厂模式.单例模式.建造者模式.原型模式 注意:工厂模式可以分为三类: 1)简单工厂模式(Simple Factory) 2)工厂 ...
- [19/04/22-星期一] GOF23_创建型模式(单例模式)
一.概念 <Design Patterns: Elements of Reusable Object-Oriented Software>(即后述<设计模式>一书),由 Eri ...
随机推荐
- 其它综合-CentOS7 忘记root密码
CentOS7 忘记root密码 长时间不用的 CentOS 机器再次开机的时候忽然忘记了密码,总不能就重装一台吧,还有好多服务在机器上,于是决定重置root的密码. 如果是已经开启的机器,需要进行关 ...
- MySQL聚簇索引和非聚簇索引的对比
首先要清楚:聚簇索引并不是一种单独的索引类型,而是一种存储数据的方式. 聚簇索引在实际中用的很多,Innodb就是聚簇索引,Myisam 是非聚簇索引. 在之前我想插入一段关于innodb和myisa ...
- Magento 最佳开发配置
概观 典型的软件开发流程如下: 本地开发机器 > QA /集成服务器 > 预览服务器(可选)> 生产服务器 无论您是在编写新的Magento 2 扩展 还是为代码库做贡献,任何开发人 ...
- 小米平板2 win10 MIUI互刷教程
在这篇文章中,我们会为大家提供Windows 10版小米平板2刷入MIUI和MIUI版小米平板2刷入Windows 10的两组教程. 不过从Win 10刷MIUI需要用原生安卓系统过渡来统一bios版 ...
- Java入门:基础算法之二进制转换为十进制
Java有两种方法可以将二进制数转换为十进制数: 1)使用Integer类的Integer.parseInt()方法. 2)自己编写转换逻辑. 方法1:使用Integer.parseInt()实现二进 ...
- Token防止表单重复提交和CSRF攻击
Token,可以翻译成标记!最大的特点就是随机性,不可预测,一般黑客或软件无法猜测出来. Token一般用在两个地方: 1: 防止表单重复提交 2: anti csrf攻击(Cross-site re ...
- Linux中的pipe(管道)与named pipe(FIFO 命名管道)
catalogue . pipe匿名管道 . named pipe(FIFO)有名管道 1. pipe匿名管道 管道是Linux中很重要的一种通信方式,是把一个程序的输出直接连接到另一个程序的输入,常 ...
- org.hibernate.ObjectNotFoundException: No row with the given identifier exists解决办法
hibernate-取消关联外键引用数据丢失抛异常的设置@NotFound hibernate项目里面配了很多many-to-one的关联,后台在查询数据时已经作了健全性判断,但还是经常抛出对象找不到 ...
- pip换源安装
pip install --index-url https://pypi.tuna.tsinghua.edu.cn/simple 要安装的 有些工具安装太慢, 换源安装一下, 速度一下子飞起
- NOI-OJ 2.2 ID:6261 汉诺塔
思路 汉诺塔是递归思想最经典的例子,通过递归不断缩小问题,将n个盘子的问题简化n-1个,直至1个. 三个盘子,分别为A:from,B:to,C:by(A为起点盘,B为目标盘,C为中转盘) 过程 将1- ...