Spring Reactor 线程调度

public static void main(String[] args) throws InterruptedException {
    Mono.create(new Consumer<MonoSink<Object>>() {
        @Override
        public void accept(MonoSink<Object> objectMonoSink) {
            System.out.println("1:" + Thread.currentThread().toString());
            objectMonoSink.success("test");
        }
    })
            //上游调度线程,只生效一次,后面的都忽略掉
            .subscribeOn(Schedulers.newSingle("Test11")).subscribeOn(Schedulers.newSingle("Test12")).subscribeOn(Schedulers.newSingle("Test13"))
            //下游调度线程,可以调用多次,在每个方法调用前声明
            .publishOn(Schedulers.newSingle("Test2")).map(new Function<Object, Object>() {
        @Override
        public Object apply(Object o) {
            System.out.println("2:" + Thread.currentThread().toString());
            return o;
        }
    }).publishOn(Schedulers.newSingle("Test3")).map(new Function<Object, Object>() {
        @Override
        public Object apply(Object o) {
            System.out.println("3:" + Thread.currentThread().toString());
            return o;
        }
    }).publishOn(Schedulers.newSingle("Test4")).flatMap(new Function<Object, Mono<Object>>() {
        @Override
        public Mono<Object> apply(Object o) {
            System.out.println("4:" + Thread.currentThread().toString());
            return Mono.create(new Consumer<MonoSink<Object>>() {
                @Override
                public void accept(MonoSink<Object> objectMonoSink) {
                    System.out.println("just:" + Thread.currentThread().toString());
                    objectMonoSink.success(o);
                }
            })
                    //上游调度线程,只生效一次,后面的都忽略掉
                    .subscribeOn(Schedulers.newSingle("just"));
        }
    }).publishOn(Schedulers.newSingle("Test5")).map(new Function<Object, Object>() {
        @Override
        public Object apply(Object o) {
            System.out.println("5:" + Thread.currentThread().toString());
            return o;
        }
    }).publishOn(Schedulers.newSingle("Test6")).subscribe(new Consumer<Object>() {
        @Override
        public void accept(Object o) {
            System.out.println("6:" + Thread.currentThread().toString());
        }
    });
    synchronized (Object.class) {
        Object.class.wait();
    }
}

输出:
1:Thread[Test11-3,5,main]
2:Thread[Test2-4,5,main]
3:Thread[Test3-5,5,main]
4:Thread[Test4-6,5,main]
just:Thread[just-7,5,main]
5:Thread[Test5-8,5,main]
6:Thread[Test6-9,5,main]
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值