17.UniRx序列(Sample、Scan、Switch、ToAwaitable/Wait、WithLastestFrom、De/Materialize、Multicast)

Sample()
Scan()
Switch()
ToAwaitableEnumerator()
Wait()
WithLatestFrom()
Materialize()
Dematerialize()
Multicast()


Sample/SampleFrame

对一个基础流进行采样,采样的数据以基础流最近输出的一个数据为准,图解
在这里插入图片描述
第一条线是基础流在输出数据
第二条线是一个Sample的流在进行采样
A采样输出1,他最近可取的数据为1;B同理,C采样不到数据,因为C最近的数据已经被Sample了;
为什么C采样不到3,因为3没有被输出,C不知道有3的存在
结束采样输出了5,因为采样结束,基础流在输出,所以输出了5

执行结果
在这里插入图片描述
代码示例

public class No17_Mixed7 : MonoBehaviour
{
   
    void Start()
    {
   
        var sample = Observable.EveryUpdate().Sample(TimeSpan.FromMilliseconds(200));
        sample.Subscribe(Next, Error, Complete);
    }

    void Next(long frame)
    {
   
        Debug.LogFormat("Sample的帧:{0}", frame);
    }

    void Error(Exception ex)
    {
   
        Debug.LogException(ex);
    }

    void Complete()
    {
   
        Debug.LogFormat("Complete");
    }
}

代码解析


Scan

对流发出的数据进行扫描,将处理的结果返回到输出,操作和内聚差不多,图解
在这里插入图片描述
执行结果
在这里插入图片描述
代码示例

public class No17_Mixed7 : MonoBehaviour
{
   
    void Start()
    {
   
        var scan = Observable.Range(1, 3).Scan(ScanMethod);
        scan.Subscribe(Next, Error, Complete);
    }

    // origin 1 2 3
    // result 1 3 6
    private int ScanMethod(int pre, int next)
    {
   
        return pre + next;
    }

    void Next(int result)
    {
   
        Debug.LogFormat("Scan之后的结果:{0}", result);
    }

    void Error(Exception ex)
    {
   
        Debug.LogException(ex);
    }

    void Complete()
    {
   
        Debug.LogFormat("Complete");
    }
}

代码解析
Range输出的值是123,经过Scan之后是136,第一个Scan的pre值为0


Switch

将多个独立输出流的输出数据汇总到一个流里面,图解
在这里插入图片描述
第一条横线是一个汇聚多个流的基础流,在输出数据,它由两个流组成,输出的数据分布是圆形和三角形;
基础流通过Switch之后,把所有的分支流全部汇总到一个流上输出
结束以最后一个流的结束标志位基准

执行结果
在这里插入图片描述
代码示例

public class No1
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,这里给您举一个使用RxJava框架的实例: 假设有一个需求,要求从一个API接口中获取用户信息并显示在界面上。我们可以使用RxJava来实现这个需求: 首先,在对应的Activity或Fragment中,我们定义一个Observable对象,用来发出网络请求并获取用户信息: ```java Observable<User> userObservable = Api.getUserInfo(userId); ``` 然后,我们可以使用subscribeOn()方法指定请求在IO线程中执行,使用observeOn()方法指定结果在主线程中回调: ```java userObservable.subscribeOn(Schedulers.io()) .observeOn(AndroidSchedulers.mainThread()) .subscribe(new Observer<User>() { @Override public void onSubscribe(Disposable d) { // 可以在这里做一些初始化操作,比如显示loading等 } @Override public void onNext(User user) { // 获取到用户信息后,更新UI显示 updateUi(user); } @Override public void onError(Throwable e) { // 出现异常时,可以做一些错误处理,比如弹出Toast提示等 showError(e.getMessage()); } @Override public void onComplete() { // 请求完成后,可以在这里做一些清理工作,比如隐藏loading等 } }); ``` 在上面的代码中,我们通过实现Observer接口来处理请求结果。在onNext()方法中,我们可以拿到获取到的用户信息,然后更新UI显示。在onError()方法中,我们可以处理请求出现异常的情况,比如弹出Toast提示。在onComplete()方法中,我们可以做一些清理工作,比如隐藏loading。 这就是一个简单的使用RxJava来获取用户信息的示例。通过使用RxJava,我们可以简化异步编程的复杂度,使代码更加清晰易读。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值