常见的有这么几种方法
第一种最简单也是最常用的,这里的所有单例init方法一定要定义成private的,不然外部依然可以使用init方法初始化变量。
final class Single: NSObject { static let shared = Single() private overrIDe init() {}}
final关键字 的作用是 这个类或方法不希望被继承和重写
第二种
@H_404_35@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() }}final class Single2: NSObject { static func shared() -> Single2 { struct Singleton { static var single = Single2() } dispatchQueue.once("YouShaoduo") { Singleton.single = shared() } return Singleton.single } private overrIDe init() {}} 第二种完全是OC风格的单例,但是由于Swift3中废弃了原来的dispatch_once_t,所以需要先给dispatchQueue添加一个extension,实现原先的 dispatch_once_t效果
第三种
private let single = Single3()final class Single3: NSObject { static var shared: Single3 { return single } fileprivate overrIDe init() {}}
第四种
final class Single4: NSObject { static var shared: Single4 { struct Static { static let instance: Single4 = Single4() } return Static.instance } private overrIDe init() {}}在方法内定义静态变量 总结
以上是内存溢出为你收集整理的Swift3 单例模式全部内容,希望文章能够帮你解决Swift3 单例模式所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)