springboot系列20,Reactive(下)

Reactor框架

核心API

Mono:0-1的非阻塞结果

Flux:0-n的非阻塞序列

Scheduler:Reactor调度线程池

接下来:实战

加依赖

        <dependency>
            <groupId>io.projectreactor</groupId>
            <artifactId>reactor-core</artifactId>
        </dependency>
public class FluxDemo {
    public static void main(String[] args){
        println("Hello World");
        Flux.just("A" , "B" , "C")  //发布数据序列,依次执行
                .subscribe(FluxDemo::println);
    }

    private static void println(Object object) {
        String threadName = Thread.currentThread().getName();
        System.out.println("线程:【" + threadName + "】  " + object);
    }
}

运行结果:

从这里可以看出,reactor并不是一定是多线程的,那如果变成多线程怎么做?使用publishOn

public class FluxDemo {
    public static void main(String[] args){
        println("Hello World");
        Flux.just("A" , "B" , "C")  //发布数据序列,依次执行
                .publishOn(Schedulers.elastic())    //切换线程池
                .subscribe(FluxDemo::println);
    }

    private static void println(Object object) {
        String threadName = Thread.currentThread().getName();
        System.out.println("线程:【" + threadName + "】  " + object);
    }
}

运行结果:

当然切换也不止这一种,其他的自己看。reactor作为流式处理,也有类似java8的Stream的处理方法,例如map

public class FluxDemo {
    public static void main(String[] args){
        println("Hello World");
        Flux.just("A" , "B" , "C")  //发布数据序列,依次执行
                .publishOn(Schedulers.elastic())    //切换线程池
                .map(oldValue -> "~" + oldValue)
                .subscribe(FluxDemo::println);
    }

    private static void println(Object object) {
        String threadName = Thread.currentThread().getName();
        System.out.println("线程:【" + threadName + "】  " + object);
    }
}

 运行结果:

从结果可以

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值