• Swift3.0 单例模式实现的几种方法-Dispatch_Once


     使用单例模式,正常我们的思路是使用GCD的dispatch_once这个API来写,然而在swift3.0中,苹果已经废弃了这个方法,不过不用担心,我们可以用别的方式来实现。结合Swift语言的特性,总结了以下几种写法:
    1. 普通创建法
    2. 静态创建法
    3. struct创建法
    4. 通过给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
    1. DispatchQueue.once(token: "com.vectorform.test") {  
    2.     print( "Do This Once!" )  
    3. }  

    或者使用UUID也可以:
    1. private let _onceToken = NSUUID().uuidString  
    2.   
    3. DispatchQueue.once(token: _onceToken) {  
    4.     print( "Do This Once!" )  
    5. }  
  • 相关阅读:
    WEB前端开发规范文档
    js九九乘法表
    阿里前端两年随想
    自动播放选项卡
    HTML+CSS编写规范
    简易秒表
    关于响应式布局
    关于PHP语言
    关于CSS3的小知识点之2D变换
    关于H5框架之Bootstrap的小知识
  • 原文地址:https://www.cnblogs.com/yujidewu/p/7052922.html
Copyright © 2020-2023  润新知