简化通知中心的使用

简介:

简化通知中心的使用

 

 

说明

1. 简化通知中心,笔者曾经实现过不需要移除的通知中心,基于弱引用集合(相对于强引用集合如NSArray,NSDictionary等)编写,本例子并无太多新意

2. 简化的通知中心由一个对象组织控制,不需要你手动移除被监听的对象,这是唯一的一点点有新意的地方

3. 在处理接收通知对象的地方,笔者提供了一个方法来简化取值操作,相对应的,发送通知消息的时候,被发送的对象也请使用指定的格式(都是用weak修饰,无需担心被持有)

 

源码

https://github.com/YouXianMing/NotificationCenter



//
//  NotificationCenterObject.h
//  NotificationCenter
//
//  Created by YouXianMing on 15/7/15.
//  Copyright (c) 2015年 YouXianMing. All rights reserved.
//

#import <Foundation/Foundation.h>


@interface PostObject : NSObject


@property (nonatomic, strong) NSString *flag;
@property (nonatomic, weak)   id        data;


/**
 *  便利构造器初始化对象
 *
 *  @param flag 识别标签
 *  @param data 数据
 *
 *  @return 实例对象
 */
+ (instancetype)postObjectWithFlag:(NSString *)flag data:(id)data;


/**
 *  处理通知中心事件
 *
 *  @param sender 通知中心的通知对象
 *
 *  @return 实例对象
 */
+ (instancetype)accessNotificationCenterObject:(id)sender;


@end


///////////////////////////////////////////////////////////////////////////////////////////


@interface NotificationCenterObject : NSObject


/**
 *  === 必须先使用此方法进行初始化 ===
 *
 *  初始化通知中心
 *
 *  @param observer 观察对象
 *  @param name     注册标签
 *  @param selector 执行用selector
 *
 *  @return 实例对象
 */
+ (instancetype)withObserver:(id)observer
                registerName:(NSString *)name
                    selector:(SEL)selector;


/**
 *  给指定注册标签发信息
 *
 *  @param name     注册标签
 *  @param postData 发送的对象
 */
+ (void)postToRegisterName:(NSString *)name data:(PostObject *)postData;


@property (nonatomic, readonly, strong) NSString *name;
@property (nonatomic, readonly, weak)   id        observer;


/**
 *  移除
 */
- (void)remove;


/**
 *  重新添加上
 */
- (void)reAdd;


@end


///////////////////////////////////////////////////////////////////////////////////////////

/**
 *  创建通知对象
 *
 *  @param flag 标签
 *  @param data 传递的数据
 *
 *  @return 通知对象
 */
static inline PostObject * POST_OBJECT(NSString *flag, id data) {
    
    return [PostObject postObjectWithFlag:flag data:data];
}

/**
 *  处理通知的对象
 *
 *  @param sender 接收的通知对象
 *
 *  @return 通知对象
 */
static inline PostObject * ACCESS_POST_OBJECT(id sender) {
    
    return [PostObject accessNotificationCenterObject:sender];
}

/**
 *  发送通知消息
 *
 *  @param name       指定的标签
 *  @param postObject 通知的对象
 *
 */
static inline void POST_MSG_TO(NSString *name, PostObject *postObject) {

    [NotificationCenterObject postToRegisterName:name data:postObject];
}

/**
 *  注册通知中心
 *
 *  @param name     指定的标签
 *  @param observer 被注册的对象
 *  @param selector 执行的句柄
 *
 *  @return 实例对象
 */
static inline NotificationCenterObject * REGISTER_MSG_CENTER_WITH(NSString *name, id observer, SEL selector) {
    
    return [NotificationCenterObject withObserver:observer registerName:name selector:selector];
}


//
//  NotificationCenterObject.m
//  NotificationCenter
//
//  Created by YouXianMing on 15/7/15.
//  Copyright (c) 2015年 YouXianMing. All rights reserved.
//

#import "NotificationCenterObject.h"

@implementation PostObject

+ (instancetype)postObjectWithFlag:(NSString *)flag data:(id)data {

    PostObject *postObject = [PostObject new];
    postObject.flag        = flag;
    postObject.data        = data;
    
    return postObject;
}

+ (instancetype)accessNotificationCenterObject:(id)sender {

    PostObject *postData = nil;
    
    if ([sender isKindOfClass:[NSNotification class]]) {
    
        NSNotification *notiData = sender;
        
        if ([notiData.object isKindOfClass:[PostObject class]]) {
            
            postData = notiData.object;
        }
    }
    
    return postData;
}

@end

@interface NotificationCenterObject ()

@property (nonatomic, strong) NSString *name;
@property (nonatomic, weak)   id        observer;
@property (nonatomic)         SEL       observerSelector;

@property (nonatomic)         BOOL      haveAddObserver;

@end

@implementation NotificationCenterObject

+ (void)postToRegisterName:(NSString *)name data:(PostObject *)postData {

    [[NSNotificationCenter defaultCenter] postNotificationName:name object:postData];
}

+ (instancetype)withObserver:(id)observer registerName:(NSString *)name selector:(SEL)selector {

    NotificationCenterObject *notificationCenterObject = [NotificationCenterObject new];
    notificationCenterObject.name                      = name;
    notificationCenterObject.observer                  = observer;
    notificationCenterObject.observerSelector          = selector;
    
    notificationCenterObject.haveAddObserver           = YES;
    [[NSNotificationCenter defaultCenter] addObserver:observer selector:selector name:name object:nil];
    
    return notificationCenterObject;
}

- (void)remove {

    if (self.haveAddObserver == YES && _name && _observer) {
        self.haveAddObserver = NO;
        [[NSNotificationCenter defaultCenter] removeObserver:_observer name:_name object:nil];
    }
}

- (void)reAdd {

    if (self.haveAddObserver == NO && _name && _observer) {
        self.haveAddObserver = YES;
        [[NSNotificationCenter defaultCenter] addObserver:_observer selector:_observerSelector name:_name object:nil];
    }
}

- (void)dealloc {
    
    if (self.haveAddObserver == YES) {
        
        NSLog(@"已经释放");
        [[NSNotificationCenter defaultCenter] removeObserver:_observer name:_name object:nil];
    }
}

@end

细节

用内联函数将OC风格函数简化为C风格函数,能够稍微缩短代码编写长度,其实并无实用价值,装的成分居多。


目录
相关文章
|
3月前
|
监控 开发者 UED
鸿蒙5.0版开发:订阅资源泄漏事件(ArkTS)
在HarmonyOS 5.0中,资源泄漏是常见问题,尤其在多线程和复杂应用逻辑下。ArkTS提供了hiAppEvent模块来订阅和处理资源泄漏事件,帮助开发者监控和优化应用性能。本文详细介绍了如何在ArkTS中订阅资源泄漏事件,并提供了示例代码。通过导入hiAppEvent和hilog模块,添加事件观察者并实现回调函数,可以在资源泄漏事件发生时进行自定义处理,如记录日志、发送通知或执行资源清理操作。
96 4
大事件项目18_个人中心_基本资料组件准备和路由
大事件项目18_个人中心_基本资料组件准备和路由
大事件项目18_个人中心_基本资料组件准备和路由
|
8月前
|
前端开发 数据库 JavaScript
基于Flowable的流程挂接自定义业务表单的设计与实践
文章讨论了如何在Flowable流程引擎中挂接自定义业务表单,以及相关设计和实践的步骤。文章中包含了一些前后端代码示例,如Vue组件的模板和脚本部分,这些代码用于实现与Flowable流程引擎交互的界面。例如,有一个按钮组件用于提交申请,点击后会触发applySubmit方法,该方法会与后端API进行交互,处理流程启动、查询关联流程等逻辑。
50217 11
|
9月前
|
前端开发
基于jeecgboot流程管理平台的自定义业务表单集成方法
基于jeecgboot流程管理平台的自定义业务表单集成方法
204 0
|
9月前
|
XML 中间件 数据库
基于jeecgboot的flowable流程支持定时边界事件
基于jeecgboot的flowable流程支持定时边界事件
153 0
|
9月前
|
前端开发
基于jeecgboot的flowable增加流程节点抄送功能
基于jeecgboot的flowable增加流程节点抄送功能
613 0
|
程序员
回调函数实现四则运算器(可增添功能)
本文讲解:回调函数实现四则运算器(可增添功能)
|
存储 API 数据库
工作流中的流程追溯!Activiti框架的历史组件详细解析
本篇文章详细说明了工作流Activiti框架中的历史组件,这个组件用于捕获发生在进程执行中的信息并对这些信息进行永久保存,在流程实例运行完成后,这些数据依旧保存在数据库中。工作流Activiti框架中提供了对历史数据的查询方法。最后介绍了历史组件的相关配置以及使用历史组件中的数据进行流程审计。通过对历史组件的学习,可以方便地对工作流的流程进行追溯。
939 0
工作流中的流程追溯!Activiti框架的历史组件详细解析
|
前端开发
【氚云】表单前、后端各种事件触发动作详解
表单前、后端各种事件触发动作详解
1116 0

热门文章

最新文章