《Python编程实战:运用设计模式、并发和程序库创建高质量程序》—— 1.5 单例模式

简介:

本节书摘来自华章出版社《Python编程实战:运用设计模式、并发和程序库创建高质量程序》一 书中的第1章,第1.1节,作者:(美) Mark Summerfield,更多章节内容可以访问云栖社区“华章计算机”公众号查看。

1.5 单例模式

在整个程序运行过程中,如果某个类只应该有一个实例,那么可通过单例模式来保证。
有些面向对象编程语言很难创建单例,但在Python语言中却非常简单。Python Cookbook(code.activestate.com/recipes/langs/python/)提供了非常易用的Singleton类,只要继承它,就会成为单例。此外还提供了Borg类,可以用另一种方式实现单例效果。
然而在Python中实现单例最为简单的办法是:创建模块时,把全局状态放在私有变量中,并提供用于访问此变量的公开函数。比方说,在第7章的currency范例中,我们要创建一个函数,令其返回含有货币汇率的字典(该字典以货币名称为键,以汇率为值)。这个函数可能会调用很多次,但大部分情况下,汇率数据只获取一次就够了,无须每次调用时都获取一遍。此需求可以通过单例模式来实现。
screenshot

这段代码节选自currency/Rates.py模块(与往常一样,节选代码时也略去了import语句)。我们创建了名为rates的字典,用于保存私有数据,并将该字典设置成Rates.get()函数的属性。第一次执行公开的get()函数时(或者以refresh=True为参数调用时),会下载全新的汇率数据;其他时候只需把最近下载的那份数据返回就行了。尽管没有引入类,但我们依然把汇率数据做成了“单例数据值”(singleton data value),若要添加其他单例值,亦可仿照此法。
创建型设计模式在Python语言中都很容易实现。单例模式可以直接用模块来实现,而原型模式则显得多余,尽管也可以通过copy模块来实现,但Python语言能够动态访问类对象,所以没必要那么做。最有用的创建型设计模式是抽象工厂模式、工厂方法模式与建造者模式,它们的实现方式有很多种。创建好基本的对象之后,一般需要通过组合或适配来创建更为复杂的对象。下一章就来谈谈这个问题。

相关文章
|
18天前
|
数据处理 UED Python
Python 进度条:告别枯燥等待,让你的程序动感十足!
Python 进度条:告别枯燥等待,让你的程序动感十足!
43 1
|
19天前
|
设计模式 存储 SQL
PHP中的设计模式:单例模式的探索
在PHP开发中,单例模式是一种常用的设计模式,它确保一个类只有一个实例,并提供一个全局访问点。本文将通过一个简单的例子,逐步引导你理解如何在PHP中实现和利用单例模式,以及它在实际项目中的应用价值。
|
12天前
|
设计模式 存储 负载均衡
【五】设计模式~~~创建型模式~~~单例模式(Java)
文章详细介绍了单例模式(Singleton Pattern),这是一种确保一个类只有一个实例,并提供全局访问点的设计模式。文中通过Windows任务管理器的例子阐述了单例模式的动机,解释了如何通过私有构造函数、静态私有成员变量和公有静态方法实现单例模式。接着,通过负载均衡器的案例展示了单例模式的应用,并讨论了单例模式的优点、缺点以及适用场景。最后,文章还探讨了饿汉式和懒汉式单例的实现方式及其比较。
【五】设计模式~~~创建型模式~~~单例模式(Java)
|
3天前
|
设计模式 XML 数据格式
python之工厂设计模式
python之工厂设计模式
python之工厂设计模式
|
2月前
|
并行计算 Python
python 并发与并行
【7月更文挑战第21天】
31 5
python 并发与并行
|
25天前
|
设计模式 安全 程序员
C#设计模式之单例模式
C#设计模式之单例模式
35 3
|
2天前
|
PHP C++ Python
右手坐标系,空间点绕轴旋转公式&程序(Python和C++程序)
右手坐标系,空间点绕轴旋转公式&程序(Python和C++程序)
6 0
|
2天前
|
Python Windows
Python编程入门:打造你的第一个程序
【8月更文挑战第29天】编程,一种现代魔法,让想象通过代码的编织成为现实。本文将带你走进Python的世界,用浅显易懂的语言和实例引导你编写出第一个程序。就像学习骑自行车一样,一开始可能会有些许不稳,但一旦掌握了技巧,前方的道路便任你驰骋。准备好了吗?让我们开始这段编程之旅吧!
|
2月前
|
IDE Linux 开发工具
Python中编写第一个 Python 程序
【7月更文挑战第27天】
24 7
|
29天前
|
消息中间件 网络协议 Python
信号传递新风尚!Python IPC,让你的程序间沟通无界限
【8月更文挑战第3天】在多程序系统中,进程间通信(IPC)是实现数据共享与协作的关键。Python提供多种IPC机制,如管道、消息队列和套接字,使信息交流高效灵活。通过`multiprocessing.Pipe()`,进程间可直接传递消息;利用消息队列实现异步通信,提高解耦与扩展性;借助socket库,支持网络内外进程通信。合理运用这些技术,能够显著增强程序间的协同能力,构建更灵活、可扩展的系统。
44 1
下一篇
云函数