欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

python中單例常用的幾種實(shí)現(xiàn)方法總結(jié)

 更新時(shí)間:2018年10月13日 11:51:37   作者:python修行路  
Python 的模塊就是天然的單例模式,下面這篇文章主要給大家介紹了關(guān)于python中單例常用的幾種實(shí)現(xiàn)方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用python單例具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們一起來(lái)看看吧

前言

最近這兩天在看自己之前寫(xiě)的代碼,所以正好把用過(guò)的東西整理一下,單例模式,在日常的代碼工作中也是經(jīng)常被用到,

所以這里把之前用過(guò)的不同方式實(shí)現(xiàn)的單例方式整理一下

什么是單例?

確保某一個(gè)類只有一個(gè)實(shí)例,而且自行實(shí)例化并向整個(gè)系統(tǒng)提供這個(gè)實(shí)例,這個(gè)類稱為單例類,單例模式是一種對(duì)象創(chuàng)建型模式。

那么單例模式有什么用途呢?舉個(gè)常見(jiàn)的單例模式例子,我們平時(shí)使用的電腦上都有一個(gè)回收站,在整個(gè)操作系統(tǒng)中,回收站只能有一個(gè)實(shí)例,整個(gè)系統(tǒng)都使用這個(gè)唯一的實(shí)例,而且回收站自行提供自己的實(shí)例,因此回收站是單例模式的應(yīng)用。

裝飾器的方式

這種方式也是工作中經(jīng)常用的一種,用起來(lái)也比較方便,代碼實(shí)現(xiàn)如下

def Singleton(cls):
 _instance = {}

 def _singleton(*args, **kwargs):
  if cls not in _instance:
   _instance[cls] = cls(*args, **kwargs)
  return _instance[cls]

 return _singleton

如果我們工作的一個(gè)類需要用單例就通過(guò)類似下面的方式實(shí)現(xiàn)即可:

@Singleton
class A(object):

 def __init__(self, x):
  self.x = x

我個(gè)人還是挺喜歡這種方式的

類的方式實(shí)現(xiàn)

這里其實(shí)有一些問(wèn)題就需要注意了,先看一下可能出現(xiàn)的錯(cuò)誤代碼

class Member(object):

 @classmethod
 def instance(cls, *args, **kwargs):
  if not hasattr(Member, "_instance"):
   Member._instance = Member(*args, **kwargs)
  return Member._instance

乍一看這個(gè)類好像已經(jīng)實(shí)現(xiàn)了單例,但是這里有一個(gè)潛在的問(wèn)題,就是如果是多線程的情況,這樣寫(xiě)就會(huì)有問(wèn)題了,尤其是在當(dāng)前類的初始化對(duì)象里有一些耗時(shí)操作時(shí)候

例如下面代碼:

#! /usr/bin/env python3
# .-*- coding:utf-8 .-*-

import time
import threading
import random


class Member(object):
 
 def __init__(self):
  time.sleep(random.randint(1,3))

 @classmethod
 def instance(cls, *args, **kwargs):
  if not hasattr(Member, "_instance"):
   Member._instance = Member(*args, **kwargs)
  return Member._instance


def task(arg):
 obj = Member.instance()
 print(obj)

for i in range(5):
 t = threading.Thread(target=task, args=[i,])
 t.start()

這段代碼的執(zhí)行結(jié)果會(huì)出現(xiàn)實(shí)例化了多個(gè)對(duì)象,導(dǎo)致你寫(xiě)的單例就沒(méi)起到作用

當(dāng)然自然而然我們會(huì)想起加鎖,通過(guò)鎖來(lái)控制,所以我們將上面代碼進(jìn)行更改:

#! /usr/bin/env python3
# .-*- coding:utf-8 .-*-


import time
import threading
import random


class Member(object):
 _instance_lock = threading.Lock()

 def __init__(self):
  i = random.randint(1, 3)
  print(i)
  time.sleep(i)

 @classmethod
 def instance(cls, *args, **kwargs):
  with Member._instance_lock:
   if not hasattr(Member, "_instance"):
    Member._instance = Member(*args, **kwargs)
  return Member._instance


def task():
 obj = Member.instance()
 print(obj)

for i in range(5):
 threading.Thread(target=task,).start()

但是上面的代碼還有一個(gè)問(wèn)題,就是當(dāng)我們已經(jīng)實(shí)例化過(guò)之后每次調(diào)用instance都會(huì)去請(qǐng)求鎖,所以這點(diǎn)并不好,所以我們將這部分代碼再次更改:

@classmethod
 def instance(cls, *args, **kwargs):
  if not hasattr(Member, "_instance"):
   with Member._instance_lock:
    if not hasattr(Member, "_instance"):
     Member._instance = Member(*args, **kwargs)
  return Member._instance

這樣就很好的實(shí)現(xiàn)一個(gè)可以多線程使用的單例

總結(jié)

以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,如果有疑問(wèn)大家可以留言交流,謝謝大家對(duì)腳本之家的支持。

相關(guān)文章

  • Python繪制散點(diǎn)圖的教程詳解

    Python繪制散點(diǎn)圖的教程詳解

    散點(diǎn)圖是指在回歸分析中,數(shù)據(jù)點(diǎn)在直角坐標(biāo)系平面上的分布圖,散點(diǎn)圖表示因變量隨自變量而變化的大致趨勢(shì),據(jù)此可以選擇合適的函數(shù)對(duì)數(shù)據(jù)點(diǎn)進(jìn)行擬合。本文將用Python繪制散點(diǎn)圖,需要的可以參考一下
    2022-03-03
  • 關(guān)于Python不換行輸出和不換行輸出end=““不顯示的問(wèn)題(親測(cè)已解決)

    關(guān)于Python不換行輸出和不換行輸出end=““不顯示的問(wèn)題(親測(cè)已解決)

    這篇文章主要介紹了關(guān)于Python不換行輸出和不換行輸出end=““不顯示的問(wèn)題(親測(cè)已解決),本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-10-10
  • tensorflow之如何使用GPU而不是CPU問(wèn)題

    tensorflow之如何使用GPU而不是CPU問(wèn)題

    這篇文章主要介紹了tensorflow之如何使用GPU而不是CPU問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-05-05
  • Python 利用切片從列表中取出一部分使用的方法

    Python 利用切片從列表中取出一部分使用的方法

    今天小編就為大家分享一篇Python 利用切片從列表中取出一部分使用的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2019-02-02
  • python數(shù)據(jù)結(jié)構(gòu)輸入輸出及控制和異常

    python數(shù)據(jù)結(jié)構(gòu)輸入輸出及控制和異常

    這篇文章主要介紹了python數(shù)據(jù)結(jié)構(gòu)輸入輸出及控制和異常,上一章節(jié)中我們介紹了python的基礎(chǔ)數(shù)據(jù)類型和集合數(shù)據(jù)類型,這章節(jié)給大家介紹一下python的輸入輸出、控制和異常,對(duì)數(shù)據(jù)類型感興趣的同學(xué)可以查看一下文章<BR>
    2021-12-12
  • 初學(xué)Python實(shí)用技巧兩則

    初學(xué)Python實(shí)用技巧兩則

    這篇文章主要介紹了初學(xué)Python實(shí)用技巧兩則,包括可變參數(shù)的應(yīng)用級(jí)execfile函數(shù)的用法,需要的朋友可以參考下
    2014-08-08
  • 快速進(jìn)修Python指南之函數(shù)進(jìn)階

    快速進(jìn)修Python指南之函數(shù)進(jìn)階

    這篇文章主要為大家介紹了Java開(kāi)發(fā)者快速進(jìn)修Python指南之函數(shù)進(jìn)階示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-12-12
  • python簡(jiǎn)單程序讀取串口信息的方法

    python簡(jiǎn)單程序讀取串口信息的方法

    這篇文章主要介紹了python簡(jiǎn)單程序讀取串口信息的方法,涉及Python操作serial模塊的技巧,需要的朋友可以參考下
    2015-03-03
  • opencv調(diào)整圖像亮度對(duì)比度的示例代碼

    opencv調(diào)整圖像亮度對(duì)比度的示例代碼

    本文通過(guò)實(shí)例代碼給大家介紹了opencv調(diào)整圖像亮度對(duì)比度,代碼簡(jiǎn)單易懂,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2019-09-09
  • 利用Python實(shí)現(xiàn)顏色色值轉(zhuǎn)換的小工具

    利用Python實(shí)現(xiàn)顏色色值轉(zhuǎn)換的小工具

    最近一個(gè)朋友說(shuō)已經(jīng)轉(zhuǎn)用Zeplin很久了。Zeplin的設(shè)計(jì)稿展示頁(yè)面的顏色色值使用十進(jìn)制的 RGB 表示的,在 Android 中的顏色表示大多情況下都需要十六進(jìn)制的 RGB 表示。所以想寫(xiě)個(gè)工作,當(dāng)輸入十進(jìn)制的RGB ,得到十六進(jìn)制的色值,最好可以方便復(fù)制。下面來(lái)一起看看吧。
    2016-10-10

最新評(píng)論