第一種
這種方式是最簡單的澈段。
<pre>import UIKit
final class Single: NSObject {
var name: String = "第一種單例" //這是測試用的屬性
static let shared = Single()
private override init() {}
}
</pre>
第二種
第二種完全是OC風(fēng)格的單例畸肆,但是由于Swift3中廢棄了原來的dispatch_once_t贫母,所以需要先給DispatchQueue添加一個extension竹宋,實現(xiàn)原先的dispatch_once_t效果
<pre>import UIKit
final class SingleShare: NSObject {
var name: String = "第二種單例"
static func shared() -> SingleShare {
struct Single {
static var single = SingleShare()
}
DispatchQueue.once(token: "SINGLE") {
Single.single = shared()
}
return Single.single
}
}
public extension DispatchQueue {
private static var onceToken = String
public class func once(token: String, block:@escaping () -> Void) {
objc_sync_enter(self)
defer {
objc_sync_exit(self)
}
if onceToken.contains(token){
return
}
onceToken.append(token)
block()
}
}</pre>
第三種
由于Swift3中加強了權(quán)限控制救斑,導(dǎo)致如果重寫private override init()方法會報錯泵琳,所以這種寫法在Swift3中的安全性有待考察心褐。
<pre>private let single = Single3()
final class Single3: NSObject {
var name: String = "第三種單例"
static var shared: Single3 {
return single
}
}</pre>
第四種
在方法內(nèi)定義靜態(tài)變量舔涎。
<pre>final class Single4: NSObject {
var name: String = "第四種單例"
static var shared: Single4{
struct Static {
static let instance: Single4 = Single4()
}
return Static.instance
}
private override init() {}
}</pre>