国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

淺談js單例模式

draveness / 986人閱讀

摘要:單例模式說到單例設計模式,中經常使用的單例模式通常分兩種,懶漢模式和餓漢模式懶漢模式簡單寫了下私有化構造函數在獲取實例的方法中返回實例化對象雖然很多大佬都寫過啦,但是小生為了加深記憶便再寫一遍雖然實現了單例模式,但是未考慮到線程安全,多個線

java單例模式

說到單例設計模式,Java中經常使用
java的單例模式通常分兩種,懶漢模式和餓漢模式

懶漢模式
class singleDemo {
    private static demoTarget;
    privete singleDemo () {};
    public static singleDemo getInstance (data) {
        if (demoTarget === null) {
           demoTarget = new singleDemo()
        }
        return demoTarget
    }
}

OK,簡單寫了下
1.私有化構造函數
2.在public獲取實例的方法中返回實例化對象

(雖然很多大佬都寫過啦,但是小生為了加深記憶便再寫一遍)
雖然實現了單例模式,但是未考慮到線程安全,多個線程訪問能可能創建多個實例,也就是高并發時候單例模式會創建多個實例,那要如何解決此類問題呢?
這時候有兩種,一種是原來的懶漢模式借助synchronized變身成為線程安全的懶漢模式,另一種則是餓漢模式

懶漢模式 (線程安全)
class singleDemo {
    private static demoTarget;
    privete singleDemo () {};
    public static synchronized singleDemo  getInstance (data) {
        if (demoTarget === null) {
            demoTarget= new singleDemo()
        }
        return demoTarget
    }
}
餓漢模式

什么是餓漢模式呢?就是在懶漢模式的基礎加一層鎖,能保證單例

class singleDemo {
    private static demoTarget = new singleDemo();
    private singleDemo () {};
    public static singleDemo getInstance (data) {
        return demoTarget
    }
}

好啦,簡單的把java常用的兩種單例模式給寫了下,???標題不是js的單例模式嘛?標題寫錯了?沒寫錯,小生只是回憶一下java的知識,望各位大佬見諒
在js中如何實現單例呢?

js單例模式

由于js都是單線程的,所以并不像java那樣麻煩,并不需要考慮多線程情況,沒錯,只要能獲取單例就行,廢話不說,代碼先上

let Single = (function () {
        function constructor () {}
        var instance;
        function getInstance(){
            if (!instance) {
                instance = new constructor()
            }
            return instance
        }
        return {
            getInstance: getInstance
        }
    })()
    const demo1 = Single.getInstance()
    const demo2 = Single.getInstance()
    console.log(demo1 === demo2) // true

文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。

轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/96118.html

相關文章

  • 淺談對JavaScript閉包的理解

    摘要:關于循環和閉包當循環和閉包結合在一起時,經常會產生讓初學者覺得匪夷所思的問題。閉包是一把雙刃劍是比較難以理解和掌握的部分,它十分強大,卻也有很大的缺陷,如何使用它完全取決于你自己。 在談閉包之前,我們首先要了解幾個概念: 什么是函數表達式? 與函數聲明有何不同? JavaScript查找標識符的機制 JavaScript的作用域是詞法作用域 JavaScript的垃圾回收機制 先來...

    missonce 評論0 收藏0
  • 淺談前端中的錯誤處理

    摘要:如何避免內存泄露內存泄漏很常見,特別是前端去寫后端程序,閉包運用不當,循環引用等都會導致內存泄漏。有的時候很難避免一些可能產生內存泄漏的問題,可以利用每次調用都在一個沙箱環境下調用,用完回收調。 某一天用戶反饋打開的頁面白屏幕,怎么定位到產生錯誤的原因呢?日常某次發布怎么確定發布會沒有引入bug呢?此時捕獲到代碼運行的bug并上報是多么的重要。 既然捕獲錯誤并上報是日常開發中不可缺少的...

    ShowerSun 評論0 收藏0
  • 淺談前端中的錯誤處理

    摘要:如何避免內存泄露內存泄漏很常見,特別是前端去寫后端程序,閉包運用不當,循環引用等都會導致內存泄漏。有的時候很難避免一些可能產生內存泄漏的問題,可以利用每次調用都在一個沙箱環境下調用,用完回收調。 某一天用戶反饋打開的頁面白屏幕,怎么定位到產生錯誤的原因呢?日常某次發布怎么確定發布會沒有引入bug呢?此時捕獲到代碼運行的bug并上報是多么的重要。 既然捕獲錯誤并上報是日常開發中不可缺少的...

    BothEyes1993 評論0 收藏0

發表評論

0條評論

最新活動
閱讀需要支付1元查看
<