ReactiveCocoa(RAC)的学习

一,它是什么

ReactiveCocoa是响应式编程(FRP)在IOS中的一个实现框架,就是用信号接管了iOS 中的所有事件。英文比较好的小伙伴可以直接去github上看它的官方说明。地址:https://github.com/ReactiveCocoa/ReactiveCocoa

        可以把信号想象成水龙头,只不过里面不是水,而是玻璃球(value),直径跟水管的内径一样,这样就能保证玻璃球是依次排列,不会出现并排的情况(数据都是线性处理的,不会出现并发情况)。水龙头的开关默认是关的,除非有了接收方(subscriber),才会打开。这样只要有新的玻璃球进来,就会自动传送给接收方。可以在水龙头上加一个过滤嘴(filter),不符合的不让通过,也可以加一个改动装置,把球改变成符合自己的需求(map)。也可以把多个水龙头合并成一个新的水龙头(combineLatest:reduce:),这样只要其中的一个水龙头有玻璃球出来,这个新合并的水龙头就会得到这个球。

ReactiveCocoa整体可以分为四个部分

信号源(事件流)  RACStream

订阅者  RACSubscriber

调度器  RACScheduler

清洁工  RACDisposable

二,它的用途

为了提高我们的开发效率。RAC在某些特定情况下开发时可以大大简化代码,并且目前来看安全可靠。在RAC的世界中,以事件流(用Signal、SignalProductor来表示)的形式,组合和转换信号,最终得到我们想要的输出,代码大统一。

1.传统iOS开发过程中,状态以及状态之间依赖过多的问题

2.传统MVC架构的问题:Controller比较复杂,可测试性差

3.提供统一的消息传递机制

三,它的使用

引用中的第一篇和第五篇讲的比较生动,具体,建议大家去看下那里面对它的实际应用。

* 1 RAC发送消息,并且绑定到控件

#pragma -mark 文本框输入事件监听

/**

* 2、为了测试此函数,增加了一个nameText;监听文本框的输入内容,并设置为self.person.name

*/

- (void)demoTextField {

@weakify(self);

[[self.nameText rac_textSignal]

subscribeNext:^(id x) {

@strongify(self);

NSLog(@"%@",x);

self.person.name = x;

}];

}

按钮监听

#pragma -mark 按钮监听

/**

* 4、验证此函数:当loginButton可以点击时,点击button输出person的属性,实现监控的效果

*/

- (void)buttonDemo {

@weakify(self);

[[self.loginButton rac_signalForControlEvents:UIControlEventTouchUpInside]

subscribeNext:^(id x) {

@strongify(self);

NSLog(@"person.name:  %@    person.password:  %@",self.person.name,self.person.password);

}

];

}

* 2 RAC代理

- (void)racProtocol {

RACSignal *programmerSignal = [self rac_signalForSelector:@selector(whoAmI) fromProtocol:@protocol(Programmer)];

[programmerSignal subscribeNext:^(id x) {

NSLog(@"RAC通知------I'm a great programmer...");

}];

@weakify(self);

dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(2.0 * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{

[self_weak_ whoAmI];

});

}

- (void)whoAmI {

NSLog(@"whoAmI------my name is %@",_user.userName);

}

demo2

#pragma -mark 代理方法

/** * 5、验证此函:nameText的输入字符时,输入回撤或者点击键盘的回车键使passWordText变为第一响应者(即输入光标移动到passWordText处) */

- (void)delegateDemo {   

    @weakify(self) 

   // 1. 定义代理    

    self.proxy = [[RACDelegateProxy alloc]initWithProtocol:@protocol(UITextFieldDelegate)];  

  // 2. 代理去注册文本框的监听方法

    [[self.proxy rac_signalForSelector:@selector(textFieldShouldReturn:)]    subscribeNext:^(id x) {   

     @strongify(self)   

     if (self.nameText.hasText) {   

         [self.passWordText becomeFirstResponder];      

  }    }]; 

   self.nameText.delegate = (id)self.proxy;

}

* 3 RAC通知

- (void)racNotification {

//接受通知并且处理

[[[NSNotificationCenter defaultCenter] rac_addObserverForName:@"RAC_Notifaciotn" object:nil] subscribeNext:^(NSNotification *notify) {

NSLog(@"notify.content = %@",notify.userInfo[@"content"]);

}];

//发出通知

[[NSNotificationCenter defaultCenter] postNotificationName:@"RAC_Notifaciotn" object:nil userInfo:@{@"content" : @"i'm a notification"}];

}

*4 RAC观察者模式(KVO)

@weakify(self);

[RACObserve(self, value) subscribeNext:^(NSString* x) {

@strongify(self);

NSLog(@"你动了");

}];

四,注意事项

在RAC的block中使用self,很容易造成循环泄漏,所以要使用@weakify和@strongify


五,引用的文章链接

这样好用的ReactiveCocoa,根本停不下来(非常推荐!!!)

iOS Reactive Cocoa使用浅析

Reactive Cocoa 技术整理

深入浅出-iOS Reactive Cocoa的常见用法

Reactive Cocoa 之旅

你可能感兴趣的:(ReactiveCocoa(RAC)的学习)