本demo詳見github
1.ReactiveCocoa簡介
ReactiveCocoa(簡稱為RAC),是由Github開源的一個(gè)應(yīng)用于iOS和OS開發(fā)的新框架宇挫。
在iOS開發(fā)過程中棠耕,經(jīng)常會(huì)響應(yīng)某些事件來處理某些業(yè)務(wù)邏輯秀存,例如按鈕的點(diǎn)擊,上下拉刷新蛉拙,網(wǎng)絡(luò)請求,屬性的變化(通過KVO)或者用戶位置的變化(通過CoreLocation)。但是這些事件都用不同的方式來處理尔店,比如action、delegate主慰、KVO嚣州、callback等。 這些我們都可以使用RAC來做到共螺。
2.RAC的思想
我們先來看看一些編程思想
- 1.面向過程:處理事情以過程為核心该肴,一步一步的實(shí)現(xiàn)(我們所已知的C語言就是面向過程的)
-
2.面向?qū)ο?/strong>:處理是以對象為點(diǎn)來處理的(OC就是面向?qū)ο蟮模?/li>
- 3.鏈?zhǔn)骄幊?/strong>:是將多個(gè)操作(多行代碼)通過點(diǎn)號(.)鏈接在一起成為一句代碼,使代碼可讀性好,如:a(1).b(2).c(3)(masonry里面就包含了鏈?zhǔn)降乃枷耄?/li>
- 4.響應(yīng)式編程(Reactive Programming):不需要考慮調(diào)用順序藐不,只需要知道考慮結(jié)果匀哄,類似于蝴蝶效應(yīng),產(chǎn)生一個(gè)事件雏蛮,會(huì)影響很多東西涎嚼,這些事件像流一樣的傳播出去,然后影響結(jié)果(KVO底層的實(shí)現(xiàn))
- 5.函數(shù)式編程(Functional Programming):把操作寫成一系列嵌套的函數(shù)或者方法來調(diào)用
- 3.鏈?zhǔn)骄幊?/strong>:是將多個(gè)操作(多行代碼)通過點(diǎn)號(.)鏈接在一起成為一句代碼,使代碼可讀性好,如:a(1).b(2).c(3)(masonry里面就包含了鏈?zhǔn)降乃枷耄?/li>
對于RAC:函數(shù)響應(yīng)式編程(FRP) 集成了上述的一些思想
下面我們來寫一個(gè):鏈?zhǔn)剿枷氲男emo
代碼如下:
CaculatorMaker.h
@interface CaculatorMaker : NSObject
/**計(jì)算結(jié)果*/
@property (nonatomic,assign)int result;
/**加法*/
-(CaculatorMaker*(^)(int))add;
/**乘法*/
-(CaculatorMaker*(^)(int))multiply;
@end
CaculatorMaker.m
#import "CaculatorMaker.h"
@implementation CaculatorMaker
-(CaculatorMaker*(^)(int))add{
return ^(int num){
self->_result += num;
return self;
};
}
-(CaculatorMaker*(^)(int))multiply{
return ^(int num){
self->_result *= num;
return self;
};
}
@end
NSObject+Caculator.h
#import <Foundation/Foundation.h>
#import "CaculatorMaker.h"
@interface NSObject (Caculator)
+(int)makeCaculator:(void (^)(CaculatorMaker * maker))block;
@end
NSObject+Caculator.m
@implementation NSObject (Caculator)
+ (int)makeCaculator:(void (^)(CaculatorMaker * maker))block{
// 創(chuàng)建計(jì)算制造者
CaculatorMaker *maker = [[CaculatorMaker alloc] init];
// 計(jì)算
block(maker);
return maker.result;
}
@end
使用:
int result = [NSObject makeCaculator:^(CaculatorMaker * _Nonnull maker) {
maker.add(10).add(20).multiply(2);
maker.multiply(10);
}];
NSLog(@"%d",result);
具體分析見下喲:
image
響應(yīng)式思想的小Demo (KVO的實(shí)現(xiàn))
下面我們再來寫一個(gè):函數(shù)式編程的小Demo
Caculator.h
#import <Foundation/Foundation.h>
@interface Caculator : NSObject
@property (nonatomic, assign) int result;
@property (nonatomic, assign) BOOL isEqule;
- (instancetype)add:(int(^)(int result))block;
- (instancetype)equle:(BOOL(^)(int result))block;
@end
Caculator.m
#import "Caculator.h"
@implementation Caculator
- (instancetype)add:(int (^)(int result))block
{
_result = block(_result);
return self;
}
- (instancetype)equle:(BOOL (^)(int))block
{
_isEqule = block(_result);
return self;
}
@end
使用:
Caculator *caculator = [[Caculator alloc] init];
BOOL isEqule = [[[caculator add:^(int result){
result += 10;
result += 20;
return result;
}] equle:^BOOL(int result) {
return result == 30;
}] isEqule];
NSLog(@"%d",isEqule);
具體分析見下喲:
image
友情鏈接: