国产睡熟迷奷白丝护士系列精品,中文色字幕网站,免费h网站在线观看的,亚洲开心激情在线

      <sup id="hb9fh"></sup>
          1. 千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機構(gòu)

            手機站
            千鋒教育

            千鋒學習站 | 隨時隨地免費學

            千鋒教育

            掃一掃進入千鋒手機站

            領(lǐng)取全套視頻
            千鋒教育

            關(guān)注千鋒學習站小程序
            隨時隨地免費學習課程

            當前位置:首頁  >  技術(shù)干貨  > Python的6種方式實現(xiàn)單例模式

            Python的6種方式實現(xiàn)單例模式

            來源:千鋒教育
            發(fā)布人:xqq
            時間: 2023-11-07 05:09:56 1699304996

            單例模式是一個軟件的設(shè)計模式,為了保證一個類,無論調(diào)用多少次產(chǎn)生的實例對象,都是指向同一個內(nèi)存地址,僅僅只有一個實例(只有一個對象)。

            實現(xiàn)單例模式的手段有很多種,但總的原則是保證一個類只要實例化一個對象,下一次再實例的時候就直接返回這個對象,不再做實例化的操作。所以這里面的關(guān)鍵一點就是,如何判斷這個類是否實例化過一個對象。

            這里介紹兩類方式:

            一類是通過模塊導入的方式;

            一類是通過魔法方法判斷的方式;

            #基本原理:

            -第一類通過模塊導入的方式,借用了模塊導入時的底層原理實現(xiàn)。

            -當一個模塊(py文件)被導入時,首先會執(zhí)行這個模塊的代碼,然后將這個模塊的名稱空間加載到內(nèi)存。

            -當這個模塊第二次再被導入時,不會再執(zhí)行該文件,而是直接在內(nèi)存中找。

            -于是,如果第一次導入模塊,執(zhí)行文件源代碼時實例化了一個類,那再次導入的時候,就不會再實例化。

            -第二類主要是基于類和元類實現(xiàn),在'對象'的魔法方法中判斷是否已經(jīng)實例化過一個對象

            -這類方式,根據(jù)實現(xiàn)的手法不同,又分為不同的方法,如:

            -通過類的綁定方法;通過元類;通過類下的__new__;通過裝飾器(函數(shù)裝飾器,類裝飾器)實現(xiàn)等。

            下面分別介紹這幾種不同的實現(xiàn)方式,僅供參考實現(xiàn)思路,不做具體需求。

            通過模塊導入

            #cls_singleton.py

            classFoo(object):

            pass

            instance=Foo()

            #test.py

            importcls_singleton

            obj1=cls_singleton.instance

            obj2=cls_singleton.instance

            print(obj1isobj2)

            #原理:模塊第二次導入從內(nèi)存找的機制

            通過類的綁定方法

            classStudent:

            _instance=None#記錄實例化對象

            def__init__(self,name,age):

            self.name=name

            self.age=age

            @classmethod

            defget_singleton(cls,*args,**kwargs):

            ifnotcls._instance:

            cls._instance=cls(*args,**kwargs)

            returncls._instance

            stu1=Student.get_singleton('jack',18)

            stu2=Student.get_singleton('jack',18)

            print(stu1isstu2)

            print(stu1.__dict__,stu2.__dict__)

            #原理:類的綁定方法是第二種實例化對象的方式,

            #第一次實例化的對象保存成類的數(shù)據(jù)屬性_instance,

            #第二次再實例化時,在get_singleton中判斷已經(jīng)有了實例對象,直接返回類的數(shù)據(jù)屬性_instance

            通過魔法方法__new__

            classStudent:

            _instance=None

            def__init__(self,name,age):

            self.name=name

            self.age=age

            def__new__(cls,*args,**kwargs):

            #ifcls._instance:

            #returncls._instance#有實例則直接返回

            #else:

            #cls._instance=super().__new__(cls)#沒有實例則new一個并保存

            #returncls._instance#這個返回是給是給init,再實例化一次,也沒有關(guān)系

            ifnotcls._instance:#這是簡化的寫法,上面注釋的寫法更容易提現(xiàn)判斷思路

            cls._instance=super().__new__(cls)

            returncls._instance

            stu1=Student('jack',18)

            stu2=Student('jack',18)

            print(stu1isstu2)

            print(stu1.__dict__,stu2.__dict__)

            #原理:和方法2類似,將判斷的實現(xiàn)方式,從類的綁定方法中轉(zhuǎn)移到類的__new__中

            #歸根結(jié)底都是判斷類有沒有實例,有則直接返回,無則實例化并保存到_instance中。

            通過元類

            classMymeta(type):

            def__init__(cls,name,bases,dic):

            super().__init__(name,bases,dic)

            cls._instance=None#將記錄類的實例對象的數(shù)據(jù)屬性放在元類中自動定義了

            def__call__(cls,*args,**kwargs):#此call會在類被調(diào)用(即實例化時觸發(fā))

            ifcls._instance:#判斷類有沒有實例化對象

            returncls._instance

            else:#沒有實例化對象時,控制類造空對象并初始化

            obj=cls.__new__(cls,*args,**kwargs)

            obj.__init__(*args,**kwargs)

            cls._instance=obj#保存對象,下一次再實例化可以直接返回而不用再造對象

            returnobj

            classStudent(metaclass=Mymeta):

            def__init__(self,name,age):

            self.name=name

            self.age=age

            stu1=Student('jack',18)

            stu2=Student('jack',18)

            print(stu1isstu2)

            print(stu1.__dict__,stu2.__dict__)

            #原理:類定義時會調(diào)用元類下的__init__,類調(diào)用(實例化對象)時會觸發(fā)元類下的__call__方法

            #類定義時,給類新增一個空的數(shù)據(jù)屬性,

            #第一次實例化時,實例化之后就將這個對象賦值給類的數(shù)據(jù)屬性;第二次再實例化時,直接返回類的這個數(shù)據(jù)屬性

            #和方式3的不同之處1:類的這個數(shù)據(jù)屬性是放在元類中自動定義的,而不是在類中顯示的定義的。

            #和方式3的不同之處2:類調(diào)用時觸發(fā)元類__call__方法判斷是否有實例化對象,而不是在類的綁定方法中判斷

            函數(shù)裝飾器

            defsingleton(cls):

            _instance_dict={}#采用字典,可以裝飾多個類,控制多個類實現(xiàn)單例模式

            definner(*args,**kwargs):

            ifclsnotin_instance_dict:

            _instance_dict[cls]=cls(*args,**kwargs)

            return_instance_dict.get(cls)

            returninner

            @singleton

            classStudent:

            def__init__(self,name,age):

            self.name=name

            self.age=age

            #def__new__(cls,*args,**kwargs):#將方法3的這部分代碼搬到了函數(shù)裝飾器中

            #ifnotcls._instance:

            #cls._instance=super().__new__(cls)

            #returncls._instan

            stu1=Student('jack',18)

            stu2=Student('jack',18)

            print(stu1isstu2)

            print(stu1.__dict__,stu2.__dict__)

            類裝飾器

            classSingleTon:

            _instance_dict={}

            def__init__(self,cls_name):

            self.cls_name=cls_name

            def__call__(self,*args,**kwargs):

            ifself.cls_namenotinSingleTon._instance_dict:

            SingleTon._instance_dict[self.cls_name]=self.cls_name(*args,**kwargs)

            returnSingleTon._instance_dict.get(self.cls_name)

            @SingleTon#這個語法糖相當于Student=SingleTon(Student),即Student是SingleTon的實例對象

            classStudent:

            def__init__(self,name,age):

            self.name=name

            self.age=age

            stu1=Student('jack',18)

            stu2=Student('jack',18)

            print(stu1isstu2)

            print(stu1.__dict__,stu2.__dict__)

            #原理:在函數(shù)裝飾器的思路上,將裝飾器封裝成類。

            #程序執(zhí)行到與語法糖時,會實例化一個Student對象,這個對象是SingleTon的對象。

            #后面使用的Student本質(zhì)上使用的是SingleTon的對象。

            #所以使用Student('jack',18)來實例化對象,其實是在調(diào)用SingleTon的對象,會觸發(fā)其__call__的執(zhí)行

            #所以就在__call__中,判斷Student類有沒有實例對象了。

            以上內(nèi)容為大家介紹了Python的6種方式實現(xiàn)單例模式,希望對大家有所幫助,如果想要了解更多Python相關(guān)知識,請關(guān)注IT培訓機構(gòu):千鋒教育。http://parentadvocate.org/

            tags: python培訓
            聲明:本站稿件版權(quán)均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
            10年以上業(yè)內(nèi)強師集結(jié),手把手帶你蛻變精英
            請您保持通訊暢通,專屬學習老師24小時內(nèi)將與您1V1溝通
            免費領(lǐng)取
            今日已有369人領(lǐng)取成功
            劉同學 138****2860 剛剛成功領(lǐng)取
            王同學 131****2015 剛剛成功領(lǐng)取
            張同學 133****4652 剛剛成功領(lǐng)取
            李同學 135****8607 剛剛成功領(lǐng)取
            楊同學 132****5667 剛剛成功領(lǐng)取
            岳同學 134****6652 剛剛成功領(lǐng)取
            梁同學 157****2950 剛剛成功領(lǐng)取
            劉同學 189****1015 剛剛成功領(lǐng)取
            張同學 155****4678 剛剛成功領(lǐng)取
            鄒同學 139****2907 剛剛成功領(lǐng)取
            董同學 138****2867 剛剛成功領(lǐng)取
            周同學 136****3602 剛剛成功領(lǐng)取
            相關(guān)推薦HOT
            Python和PHP的區(qū)別

            從開發(fā)的角度來看,PHP是面向WEB的語言。PHP應(yīng)用程序更像是一組單獨的腳本,甚至只是一個單獨入口。而Python是多用途語言,也可以用于WEB開發(fā),...詳情>>

            2023-11-07 08:02:45
            Python爬蟲原理

            簡單來說互聯(lián)網(wǎng)是由一個個站點和網(wǎng)絡(luò)設(shè)備組成的大網(wǎng),我們通過瀏覽器訪問站點,站點把HTML、JS、CSS代碼返回給瀏覽器,這些代碼經(jīng)過瀏覽器解析...詳情>>

            2023-11-07 07:33:56
            使用Cython為Python編寫更快的C擴展

            使用Python很有趣,但有時,用它編寫的程序可能很慢。所有的運行時動態(tài)調(diào)度會帶來很大的代價:有時它比用C或Rust等系統(tǒng)語言編寫的等效代碼慢10...詳情>>

            2023-11-07 07:23:08
            Python字符串連接

            字符串是Python中常用的數(shù)據(jù)類型,在開發(fā)過程中可以對字符創(chuàng)進行截取并與其他字符創(chuàng)進行連接。下面小編整理了5種方法完成Python字符創(chuàng)的連接!加...詳情>>

            2023-11-07 06:47:08
            數(shù)據(jù)科學中必須了解的Python核心庫

            python有三個核心數(shù)據(jù)科學庫,在此基礎(chǔ)上還創(chuàng)建了許多其他的庫。這三個核心數(shù)據(jù)科學庫分別為:NumpyScipyMatplotlib簡單起見,可以把Numpy視為...詳情>>

            2023-11-07 06:39:56