本人有若干成套学习视频, 可试看! 可试看! 可试看, 重要的事情说三遍 包含Java
, 数据结构与算法
, iOS
, 安卓
, python
, flutter
等等, 如有需要, 联系微信tsaievan
.
RAC中有一些特别牛逼的宏, 牛逼到什么程度呢? 牛逼到看都看不懂. 所以别人作者的潜台词就是告诉你: 会用就行了.
下面就来总结一下RAC中常见的, 吊到炸毛的宏:
RAC(TARGET, ...)
分配一个信号给一个对象的属性, 只要有新的信号产生, 就自动分配给特定的key
, 当信号完成时, 绑定自动废弃.
RAC(_targetLabel,text) = _textField.rac_textSignal;
一行代码, 搞定, 完成效果如下:
RAC宏实现效果-
RACObserve(TARGET, KEYPATH)
替代KVO的宏:
当TARGET
的KEYPATH
发生变化时, 就会产生新的信号.
[RACObserve(_targetLabel, text) subscribeNext:^(id _Nullable x) {
NSLog(@"%@", x);
}];
RACTuplePack(...)
利用指定的值包装成新的元祖. 至少指定一个值,值可以是nil
RACTuple *tuple = RACTuplePack(@"abc", @"efg");
NSLog(@"%@", tuple[0]);
运行结果如下:
打印结果
RACTupleUnpack(...)
声明新的对象变量, 并将元祖解包后赋值给这些变量
这个宏需要放在=
的左边, 元祖放在=
右边, 且这一行代码不能还出现别的东西. 这个宏不能是条件判断语句或者循环体内唯一的语句,
- 如果元祖包含的值多于声明的变量, 那么元祖包含的多余的值将被忽略
- 如果元祖包含的值少于声明的变量, 那么多出来的变量将会被赋值为
nil
RACTuple *tuple = RACTuplePack(@"abc", @"efg");
RACTupleUnpack(NSString *string1,NSString *string2) = tuple;
NSLog(@"%@---%@",string1,string2);
运行结果如下:
解包的宏打印的结果-
@weakify(...)
&@strongify(...)
解除循环引用必备神器
@weakify(...)
给其中的参数变量创建一个C语言的__weak修饰的影子变量, 这些影子变量随后又会被@strongify(...)
修饰, 重新成为强引用的变量
在block中, 这个宏用弱引用变量, 但在block执行的时候, 要确保该变量一直存在
@strongify(...)
将参数变量强引用, 但前提是, 这些参数之前要被@weakify(...)
修饰过, 这个宏将覆盖掉初始的变量名, 所以在当前作用域使用原来的变量名并不会引起循环引用:
id foo = [[NSObject alloc] init];
id bar = [[NSObject alloc] init];
@weakify(foo, bar);
// this block will not keep 'foo' or 'bar' alive
BOOL (^matchesFooOrBar)(id) = ^ BOOL (id obj){
// but now, upon entry, 'foo' and 'bar' will stay alive until the block has
// finished executing
@strongify(foo, bar);
return [foo isEqual:obj] || [bar isEqual:obj];
};
网友评论