Swift 實現單例模式Singleton pattern的三種方法

來源:互聯網
上載者:User

標籤:

轉自:點擊開啟連結

From my short experience with Swift there are three approaches to implement the Singleton pattern that support lazy initialization and thread safety.

These approaches might change or become redundant as the language matures.

Global constant

let _SingletonSharedInstance = Singleton()

 

class Singleton  {

    class var sharedInstance : Singleton {

        return _SingletonSharedInstance

    }

}

We use a global constant because class constants are not yet supported.

This approach supports lazy initialization because Swift lazily initializes global constants (and variables), and is thread safe by virtue of let.

Nested struct

class Singleton {

    class var sharedInstance : Singleton {

        struct Static {

            static let instance : Singleton = Singleton()

        }

        return Static.instance

    }

}

Unlike classes, structs do support static constants. By using a nested struct we can leverage its static constant as a class constant.

dispatch_once

The traditional Objective-C approach ported to Swift. I‘d say it‘s no longer necessary to use this approach but I‘m putting it here anyway as I find the differences in syntax interesting.

class Singleton {

    class var sharedInstance : Singleton {

        struct Static {

            static var onceToken : dispatch_once_t = 0

            static var instance : Singleton? = nil

        }

        dispatch_once(&Static.onceToken) {

            Static.instance = Singleton()

        }

        return Static.instance!

    }

}

Swift 實現單例模式Singleton pattern的三種方法

相關文章

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.