iOS开发RAC学习笔记(九)信号的一些延时,重复等操作

对信号的一些执行操作

send信号前执行相应的block
    //doNext doComplete doError中的block会分别在对应的sendNext sendComplete sendError之前执行
    [[[[self.testSignal doNext:^(id x) {

        NSLog(@"sendNext之前会执行这个block");

    }] doCompleted:^{

        NSLog(@"sendComplete之前会执行这个block");

    }] doError:^(NSError *error) {

        NSLog(@"sendError之前会执行这个block");

    }] subscribeNext:^(id x) {

        NSLog(@"%@",x);

    }];
超时自动报错
    [[self.testSignal timeout:1 onScheduler:[RACScheduler mainThreadScheduler]] subscribeNext:^(id x) {

        NSLog(@"%@",x);

    } error:^(NSError *error) {

        //超时一秒后会自动报错
        NSLog(@"%@",error);

    }];
定时执行

和前面讲的定时器类似

    //每一秒执行一次,这里要加上释放信号,否则控制器推出后依旧会执行,看具体需求吧
    [[[RACSignal interval:1 onScheduler:[RACScheduler scheduler]]takeUntil:self.rac_willDeallocSignal ] subscribeNext:^(id x) {

        NSLog(@"%@",[NSDate date]);

    }];
延时执行
    [[self.testSignal delay:2] subscribeNext:^(id x) {

        NSLog(@"%@",[NSDate date]);

    }];
信号发送失败后会重新执行
    [[self.testSignal retry] subscribeNext:^(id x) {

        NSLog(@"%@",x);

    } error:^(NSError *error) {

        NSLog(@"%@",error);

    }];
当一个信号被多次订阅后会像热信号那样

当一个信号被多次订阅时,不会每次都执行一遍副作用,而是像热信号一样只执行一遍,replay内部将信号封装RACMulticastConnection的热信号

拿示例来说第一个例子我们不对信号进行replay操作

    RACSignal *signal = [RACSignal createSignal:^RACDisposable *(id<RACSubscriber> subscriber) {

        static int a = 1;

        [subscriber sendNext:@(a)];

        a ++;

        return nil;

    }];

    [signal subscribeNext:^(id x) {

        NSLog(@"第一个订阅者%@",x);

    }];

    [signal subscribeNext:^(id x) {

        NSLog(@"第二个订阅者%@",x);

    }];
  • 输出结果如下

      2016-09-02 11:57:50.312 Signal processing[3703:323215] 第一个订阅者1
      2016-09-02 11:57:50.312 Signal processing[3703:323215] 第二个订阅者2

这个结果说明了冷信号的本质以及副作用,每订阅一次冷信号,都会完整的执行一次副作用

下来对冷信号进行replay操作

    RACSignal *signal = [[RACSignal createSignal:^RACDisposable *(id<RACSubscriber> subscriber) {

        static int a = 1;

        [subscriber sendNext:@(a)];

        a ++;

        return nil;
    }] replay];

    [signal subscribeNext:^(id x) {

        NSLog(@"第一个订阅者%@",x);

    }];

    [signal subscribeNext:^(id x) {

        NSLog(@"第二个订阅者%@",x);

    }];
  • 输出结果如下

      2016-09-02 11:59:44.352 Signal processing[3782:328331] 第一个订阅者1
      2016-09-02 11:59:44.352 Signal processing[3782:328331] 第二个订阅者1

由此可以看出,实际上是将冷信号只发送了一次

节流

对信号使用throttle这个方法,原理就是类似若一段时间后没有新信号就执行最后这个信号,前面讲的即时搜索的优化就是一个很好的例子,主要用在降低服务器压力以及其他一些信号发送频繁,但订阅却不需要如此频繁的地方.

    [[signal throttle:1] subscribeNext:^(id x) {

        NSLog(@"%@",x);

    }];
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值