一. 工程准备

maven依赖:

        <dependency>
            <groupId>ch.qos.logback</groupId>
            <artifactId>logback-classic</artifactId>
            <version>1.4.6</version>
        </dependency>
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <version>1.18.26</version>
        </dependency>
        <!-- https://mvnrepository.com/artifact/io.projectreactor/reactor-core -->
        <dependency>
            <groupId>io.projectreactor</groupId>
            <artifactId>reactor-core</artifactId>
            <version>3.5.5</version>
        </dependency>
        <dependency>
            <groupId>io.projectreactor</groupId>
            <artifactId>reactor-test</artifactId>
            <scope>test</scope>
            <version>3.5.5</version>
        </dependency>
        <dependency>
            <groupId>org.assertj</groupId>
            <artifactId>assertj-core</artifactId>
            <version>3.24.2</version>
            <scope>test</scope>
        </dependency>
        <dependency>
            <groupId>junit</groupId>
            <artifactId>junit</artifactId>
            <version>4.13.2</version>
            <scope>test</scope>
        </dependency>

简单示例:

package org.example.reactor;

import lombok.SneakyThrows;
import lombok.extern.slf4j.Slf4j;
import org.junit.Test;
import reactor.core.publisher.ConnectableFlux;
import reactor.core.publisher.Flux;
import reactor.core.publisher.Mono;
import reactor.core.scheduler.Schedulers;
import reactor.test.StepVerifier;

import java.time.Duration;
import java.util.concurrent.CountDownLatch;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.TimeUnit;

@Slf4j
public class ReactorTest {
    @Test
    public void test() {
        // Flux支持多条数据
        Flux.just(1, 2, 3).subscribe(i -> log.debug("Flux: {}", i));

        // Mono支持0或者1条数据
        Mono.just(1).subscribe(i -> log.debug("Mono: {}", i));

        // 创建一个error的flux
        Flux.error(new Exception("error")).subscribe(
                e -> log.debug("error: {}", e),
                e -> log.error("error", e),
                () -> log.debug("Completed!")
        );

        // flux测试
        StepVerifier.create(Flux.just(1, 2)) //1
                .expectNext(1, 2) //2
                .expectComplete() //3
                .verify(); //4
    }

    @Test
    public void switchSyncToAsyncTest() {
        ExecutorService executorService = Executors.newSingleThreadExecutor();
        CountDownLatch countDownLatch = new CountDownLatch(1);

        log.debug("main thread");
        Mono.fromCallable(this::syncMethod)
                .subscribeOn(Schedulers.fromExecutor(executorService))
                .subscribe(e -> log.debug("element = {}", e), null, countDownLatch::countDown);

        try {
            countDownLatch.await();
        } catch (InterruptedException e) {
            e.printStackTrace();
        }

    }

    private Integer syncMethod() {

        try {
            TimeUnit.SECONDS.sleep(2);
        } catch (InterruptedException e) {
            e.printStackTrace();
        }

        return 123456;
    }

    @SneakyThrows
    @Test
    public void test3() {
        final Flux<Long> source = Flux.interval(Duration.ofSeconds(1L))
                .log()
                .take(10)
                .publish()
                .autoConnect();
        source.subscribe(e -> log.debug("subscribe {}", e));
        Thread.sleep(5000);
        source.toStream().forEach(e -> log.debug("foreach {}", e));
    }

    @Test
    public void test6() {
        ConnectableFlux<Object> publish = Flux.create(fluxSink -> {
                    while (true) {
                        fluxSink.next(System.currentTimeMillis());
                    }
                })
                .log()
                .sample(Duration.ofSeconds(2))
                .publish();

        publish.subscribe(System.out::println);
        publish.connect();
    }
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值