Swift - 使用NotificationCenter发送通知,接收通知
作者:hangge | 2015-08-16 17:28
(本文代码已升级至Swift3)
观察者模式 (Observer):指一个对象在状态变化的时候会通知另一个对象。参与者并不需要知道其他对象的具体是干什么的 。这是一种降低耦合度的设计。常见的使用方法是观察者注册监听,然后在状态改变的时候,所有观察者们都会收到通知。
Cocoa 使用两种方式实现了观察者模式: 一个是 Key-Value Observing (KVO),另一个便是本文要讲的 Notification。
3,使用自定义的通知
--- ViewController.swift ---
--- MyObserver.swift ---
运行结果如下:
(通过运行可以看出,通知发送后的执行时同步的,也就是观察者全部处理完毕后,主线程才继续往下进行。)
1,通知(Notification)介绍
这里所说的通知不是指发给用户看的通知消息,而是系统内部进行消息传递的通知。要介绍通知之前,我们需要先了解什么是观察者模式。
在 MVC 里,观察者模式意味着需要允许 Model 对象和 View 对象进行交流,而不能有直接的关联。
2,系统通知的注册和响应
比如我们想要在用户按下设备的home键,程序进入后台时执行某些操作。一种办法是在 AppDelegate.swift 里的 applicationDidEnterBackground 方法里执行。
除此之外,由于程序进入后台会发送 UIApplicationDidEnterBackground 的通知,我们可以事先注册个监听这个通知的“观察者”来处理。
import UIKit class ViewController: UIViewController { override func viewDidLoad() { super.viewDidLoad() let notificationCenter = NotificationCenter.default let operationQueue = OperationQueue.main let observer = notificationCenter.addObserver( forName: NSNotification.Name.UIApplicationDidEnterBackground, object: nil, queue: operationQueue, using: { (notification) in print("程序进入到后台了") }) //如果不需要的话,记得把相应的通知注册给取消,避免内存浪费或奔溃 //notificationCenter.removeObserver(observer) } override func didReceiveMemoryWarning() { super.didReceiveMemoryWarning() } }
3,使用自定义的通知
通知类型其实就是一个字符串,所以我们也可以使用自己定义的通知(同时也可以传递用户自定义数据)。
下面创建了两个观察者获取下载图片通知,同时收到通知后的处理函数内部添加了个3秒的等待。
--- ViewController.swift ---
import UIKit class ViewController: UIViewController { let observers = [MyObserver(name: "观察器1"),MyObserver(name: "观察器2")] override func viewDidLoad() { super.viewDidLoad() print("发送通知") let notificationName = Notification.Name(rawValue: "DownloadImageNotification") NotificationCenter.default.post(name: notificationName, object: self, userInfo: ["value1":"hangge.com", "value2" : 12345]) print("通知完毕") } override func didReceiveMemoryWarning() { super.didReceiveMemoryWarning() } }
--- MyObserver.swift ---
import UIKit class MyObserver: NSObject { var name:String = "" init(name:String){ super.init() self.name = name let notificationName = Notification.Name(rawValue: "DownloadImageNotification") NotificationCenter.default.addObserver(self, selector:#selector(downloadImage(notification:)), name: notificationName, object: nil) } func downloadImage(notification: Notification) { let userInfo = notification.userInfo as! [String: AnyObject] let value1 = userInfo["value1"] as! String let value2 = userInfo["value2"] as! Int print("\(name) 获取到通知,用户数据是[\(value1),\(value2)]") sleep(3) print("\(name) 执行完毕") } deinit { //记得移除通知监听 NotificationCenter.default.removeObserver(self) } }
运行结果如下:
(通过运行可以看出,通知发送后的执行时同步的,也就是观察者全部处理完毕后,主线程才继续往下进行。)
全部评论(5)
很喜欢,一直追随!非常感谢!
站长回复:不客气,欢迎继续关注hangge.com。我会创作更多的文章分享给大家。
寫的超級棒!
站长回复:谢谢你的夸奖,欢迎常来看看。
写的很好,加油哈!
站长回复:谢谢支持,欢迎常来看看!
赞
站长回复:谢谢
你的文章写的非常好
讲NSNotification还顺带聊观察者模式,带到了KVO,知识很全面 :)
站长回复:谢谢你能喜欢