使用单例模式,正常我们的思路是使用GCD的dispatch_once这个API来写,然而在swift3.0中,苹果已经废弃了这个方法,不过不用担心,我们可以用别的方式来实现。结合Swift语言的特性,总结了以下几种写法:
- 普通创建法
- 静态创建法
- struct创建法
- 通过给DIspatchQueue添加扩展实现
注意这里我希望大家除了使用还要会调用该对应的方法
1.普通创建法
//MARK - : 单例:方法1
static let shareSingleOne = Single()
2.静态创建法
let single = Single()
class Single: NSObject {
//-MARK: 单例:方法2
class var sharedInstance2 : Single {
return single
}
}
3.struct创建法
//-MARK: 单例:方法3
static var shareInstance3:Single{
struct MyStatic{
static var instance :Single = Single()
}
return MyStatic.instance;
}
4.通过给DispatchQueue添加扩展实现
public extension DispatchQueue {
private static var _onceTracker = [String]()
/**
Executes a block of code, associated with a unique token, only once. The code is thread safe and will
only execute the code once even in the presence of multithreaded calls.
- parameter token: A unique reverse DNS style name such as com.vectorform.<name> or a GUID
- parameter block: Block to execute once
*/
public class func once(token: String, block:()->Void) {
objc_sync_enter(self)
defer { objc_sync_exit(self) }
if _onceTracker.contains(token) {
return
}
_onceTracker.append(token)
block()
}
}
使用字符串token作为once的ID,执行once的时候加了一个锁,避免多线程下的token判断不准确的问题。
使用的时候可以传token
使用的时候可以传token
- DispatchQueue.once(token: "com.vectorform.test") {
- print( "Do This Once!" )
- }
或者使用UUID也可以:
- private let _onceToken = NSUUID().uuidString
- DispatchQueue.once(token: _onceToken) {
- print( "Do This Once!" )
- }