博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Swift - 使用NSNotificationCenter发送通知,接收通知
阅读量:5253 次
发布时间:2019-06-14

本文共 2780 字,大约阅读时间需要 9 分钟。

1,通知(NSNotification)介绍

这里所说的通知不是指发给用户看的通知消息,而是系统内部进行消息传递的通知。要介绍通知之前,我们需要先了解什么是观察者模式。

观察者模式 (Observer):指一个对象在状态变化的时候会通知另一个对象。参与者并不需要知道其他对象的具体是干什么的 。这是一种降低耦合度的设计。常见的使用方法是观察者注册监听,然后在状态改变的时候,所有观察者们都会收到通知。 

在 MVC 里,观察者模式意味着需要允许 Model 对象和 View 对象进行交流,而不能有直接的关联。

Cocoa 使用两种方式实现了观察者模式: 一个是 Key-Value Observing (KVO),另一个便是本文要讲的Notification。

2,系统通知的注册和响应
比如我们想要在用户按下设备的home键,程序进入后台时执行某些操作。一种办法是在AppDelegate.swift里的applicationDidEnterBackground方法里执行。
除此之外,由于程序进入后台会发送 UIApplicationDidEnterBackgroundNotification 的通知,我们可以事先注册个监听这个通知的“观察者”来处理。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
import UIKit
 
class ViewController: UIViewController {
     
    override func viewDidLoad() {
        super.viewDidLoad()
         
        let notificationCenter = NSNotificationCenter.defaultCenter()
         
        let operationQueue = NSOperationQueue.mainQueue()
         
        let applicationDidEnterBackgroundObserver =
            notificationCenter.addObserverForName(UIApplicationDidEnterBackgroundNotification,
                object: nil, queue: operationQueue, usingBlock: {
                (notification: NSNotification!) in
                    print("程序进入到后台了")
        })
         
        //如果不需要的话,记得把相应的通知注册给取消,避免内存浪费或奔溃
        //notificationCenter.removeObserver(applicationDidEnterBackgroundObserver)
    }
     
    override func didReceiveMemoryWarning() {
        super.didReceiveMemoryWarning()
    }
}

3,使用自定义的通知 

通知类型其实就是一个字符串,所以我们也可以使用自己定义的通知(同时也可以传递用户自定义数据)。
下面创建了两个观察者获取下载图片通知,同时收到通知后的处理函数内部添加了个3秒的等待。

--- ViewController.swift ---

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
import UIKit
 
class ViewController: UIViewController {
     
    let observers = [MyObserver(name: "观察器1"),MyObserver(name: "观察器2")]
 
    override func viewDidLoad() {
        super.viewDidLoad()
         
        print("发送通知")
        NSNotificationCenter.defaultCenter().postNotificationName("DownloadImageNotification",
            object: self, userInfo: ["value1":"hangge.com", "value2" : 12345])
        print("通知完毕")
    }
     
    override func didReceiveMemoryWarning() {
        super.didReceiveMemoryWarning()
    }
}

--- MyObserver.swift ---

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
import UIKit
 
class MyObserver: NSObject {
     
    var name:String = ""
 
    init(name:String){
        super.init()
         
        self.name = name
        NSNotificationCenter.defaultCenter().addObserver(self, selector:"downloadImage:",
            name: "DownloadImageNotification", object: nil)
    }
     
    func downloadImage(notification: NSNotification) {
        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 {
        //记得移除通知监听
        NSNotificationCenter.defaultCenter().removeObserver(self)
    }
    
}

运行结果如下:

发送通知
观察器1 获取到通知,用户数据是[hangge.com,12345]
观察器1 执行完毕
观察器2 获取到通知,用户数据是[hangge.com,12345]
观察器2 执行完毕
通知完毕

通过运行可以看出,通知发送后的执行时同步的,也就是观察者全部处理完毕后,主线程才继续往下进行。)

转载于:https://www.cnblogs.com/Free-Thinker/p/5090806.html

你可能感兴趣的文章
很好的资源
查看>>
php sockets扩展安装
查看>>
补题日记 + 总结 从2016-10-21至今
查看>>
2019年上半年收集到的人工智能图神经网络干货文章
查看>>
Go Web开发之Revel - 拦截器
查看>>
Spring Cloud Gateway重试机制
查看>>
SQLAlchemy
查看>>
关于工厂模式的想法
查看>>
FPGA IN 金融领域
查看>>
VC++学习(17):进程间通信
查看>>
PHY6202和NRF51822\51802的区别
查看>>
刷题 | 数组去重的4种方法引发的思考
查看>>
如何获取 android 的系统日志 logcat
查看>>
Java递归方法遍历二叉树的代码
查看>>
Lucene全文搜索之分词器:使用IK Analyzer中文分词器(修改IK Analyzer源码使其支持lucene5.5.x)...
查看>>
使用Oracle数据库实现树形结构表的子-父级递归查询和删除,通过级联菜单简单举例...
查看>>
DOM操作HTML元素属性
查看>>
.net core自定义特性操作
查看>>
网页消息推送-Comet (web技术)
查看>>
common.js 2017
查看>>