ReactiveCocoa
是iOS广为使用的技术框架, 而ReactiveCocoa
核心思想就是FRP
,FRP
不同于JAVA的object-oriented
和AOP
(面向切面编程) ,FRP
能让你的代码像数学一样简洁,业务像流水一样清晰流畅。
函数响应式编程
响应式编程思想为体, 函数式编程思想为用
函数式编程
作为一个iOS开发者, 一定用过 Masonr
和 SnapKit
吧?
- Masonry是一个OC开发中,非常好用的自动布局的第三方框架;
- SnapKit是Masonry团队打造的swift版本的自动布局框架;
一个典型的Masonry语句
make.centerY.equalTo(self.view).offset(100);
这个.
非常鲜明的展现给了开发者, Masnory/ SnapKit
函数式编程的一个经典的代表作
下面具体实现以下函数式编程:
- 新建项目
cmmand + shift + n
- 创建一个
Person
类 - 添加两个方法, 并实现
- (void)run;
- (void)study;
- (void)run {
NSLog(@"run");
}
- (void)study {
NSLog(@"study");
}
- 调用相关方法
[person run];
[person study];
期待实现的目标:
person.runBlock().studyBlock();
person.studyBlock().runBlock();
可以先实现
[[person run1] study1];
[[person study1] run1];
- 添加方法
- (Person *)run1;
- (Person *)study1;
- 实现方法
- (Person *)run1 {
NSLog(@"run");
return [Person new];
}
- (Person *)study1 {
NSLog(@"study");
return [Person new];
}
- 调用方法
[[person run1] study1];
[[person study1] run1];
最终实现:
person.runBlock().studyBlock();
在Objective-C
中, block
都是以 ()
形式执行的, 如果返回一个block
, 就可以用括号来实现runblock()
这种效果了!
runBlock()
代表执行了一个 block , 如果返回是一个对象, 那么就可以一直链接下去了, 从而实现我们的目标!
- 添加方法
- (Person *(^)(void))runBlock;
- (Person *(^)(void))studyBlock;
- 实现方法
- (Person *(^)(void))runBlock {
Person *((^block)(void)) = ^() {
NSLog(@"run");
return self;
};
return block;
}
- (Person *(^)(void))studyBlock {
Person *((^block)(void)) = ^() {
NSLog(@"study");
return self;
};
return block;
}
- 调用方法
person.runBlock().studyBlock();
person.studyBlock().runBlock();
最后看一下Masonry
的函数式编程
make.right.equalTo(self.right).insets(kPadding);
最终调用的函数:返回的就是一个返回值为MASConstraint
的block
- (MASConstraint* (^)(id))equalTo {
return ^id(idattribute) {
return self.equalToWithRelation(attribute,NSLayoutRelationEqual);
};
}
函数式编程总结
- 如果想去调用别的方法, 就要返回一个对象
- 如果想用
()
去执行, 就要返回一个block
- 如果想让
block
再调用对象的方法, 那么block
就需要返回一个对象(即返回一个值为对象的block
)
响应式编程
例如,在命令式编程环境中, a = b + c 表示将表达式的结果赋给 a,而之后改变 b 或 c 的值不会影响 a。但在响应式编程中,a的值会随着 b 或 c 的更新而更新。
在响应式编程当中,a = b + c 声明的是一种绑定关系。( a 与 b、c 绑定起来了,所以 b、c 的变化会影响 a,这也就是所谓【变化传播】)