mirror of
https://github.com/OtusTeam/Spring.git
synced 2026-05-30 10:50:42 +00:00
L20 rxJava
This commit is contained in:
@@ -0,0 +1,7 @@
|
||||
.idea/
|
||||
*.iml
|
||||
|
||||
target/
|
||||
|
||||
/node_modules
|
||||
/output
|
||||
@@ -0,0 +1,40 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project xmlns="http://maven.apache.org/POM/4.0.0"
|
||||
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
|
||||
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
|
||||
<modelVersion>4.0.0</modelVersion>
|
||||
|
||||
<groupId>ru.otus</groupId>
|
||||
<artifactId>spring-20-rxjava</artifactId>
|
||||
<version>1.0-SNAPSHOT</version>
|
||||
|
||||
<parent>
|
||||
<groupId>org.springframework.boot</groupId>
|
||||
<artifactId>spring-boot-starter-parent</artifactId>
|
||||
<version>3.0.2</version>
|
||||
</parent>
|
||||
|
||||
<properties>
|
||||
<maven.compiler.source>17</maven.compiler.source>
|
||||
<maven.compiler.target>17</maven.compiler.target>
|
||||
</properties>
|
||||
|
||||
<dependencies>
|
||||
<dependency>
|
||||
<groupId>io.reactivex.rxjava2</groupId>
|
||||
<artifactId>rxjava</artifactId>
|
||||
<version>2.2.21</version>
|
||||
</dependency>
|
||||
<dependency>
|
||||
<groupId>ch.qos.logback</groupId>
|
||||
<artifactId>logback-classic</artifactId>
|
||||
<version>1.4.6</version>
|
||||
</dependency>
|
||||
<dependency>
|
||||
<groupId>backport-util-concurrent</groupId>
|
||||
<artifactId>backport-util-concurrent</artifactId>
|
||||
<version>3.1</version>
|
||||
<scope>compile</scope>
|
||||
</dependency>
|
||||
</dependencies>
|
||||
</project>
|
||||
@@ -0,0 +1,67 @@
|
||||
package ru.otus;
|
||||
|
||||
import io.reactivex.Observable;
|
||||
import io.reactivex.disposables.Disposable;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
|
||||
public class CreateExample {
|
||||
private static final Logger logger = LoggerFactory.getLogger(CreateExample.class);
|
||||
|
||||
public static void main(String[] args) {
|
||||
//onEachNext();
|
||||
//lazyObservable();
|
||||
//creatorExample();
|
||||
}
|
||||
|
||||
private static void onEachNext() {
|
||||
Observable<String> obs = Observable.just("one", "two", "three");
|
||||
obs.doOnEach(item -> logger.info("item_1:{}", item.getValue()))
|
||||
.subscribe();
|
||||
logger.info("-----");
|
||||
obs.doOnNext(item -> logger.info("item_2:{}", item))
|
||||
.map(String::length)
|
||||
.doOnNext(item -> logger.info("length_2:{}", item))
|
||||
.subscribe();
|
||||
}
|
||||
|
||||
private static void lazyObservable() {
|
||||
Observable<String> obs = Observable.defer(() -> {
|
||||
logger.info("creating new Observable");
|
||||
return Observable.just("one", "two", "three");
|
||||
});
|
||||
|
||||
obs.doOnNext(item -> logger.info("item_1:{}", item))
|
||||
.subscribe();
|
||||
|
||||
logger.info("---------------");
|
||||
|
||||
obs.doOnNext(item -> logger.info("item_2:{}", item))
|
||||
.subscribe();
|
||||
}
|
||||
|
||||
private static void creatorExample() {
|
||||
Observable<String> obs = Observable.create(emitter -> {
|
||||
emitter.onNext("one");
|
||||
emitter.onNext("two");
|
||||
|
||||
emitter.onError(new RuntimeException("Error!"));
|
||||
|
||||
emitter.onNext("three");
|
||||
emitter.onComplete();
|
||||
});
|
||||
|
||||
obs.onExceptionResumeNext(Observable.just("r1", "r2", "r3"))
|
||||
.doOnNext(item -> logger.info("item__1:{}", item))
|
||||
.subscribe();
|
||||
|
||||
logger.info("---------------");
|
||||
|
||||
Disposable disposable = obs.doOnNext(item -> logger.info("item__2:{}", item))
|
||||
.subscribe(next -> logger.info("next:{}", next),
|
||||
error -> logger.info("error:{}", error.getMessage()),
|
||||
() -> logger.info("onComplete"));
|
||||
|
||||
logger.info("isDisposed:{}", disposable.isDisposed());
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,43 @@
|
||||
package ru.otus;
|
||||
|
||||
import io.reactivex.Observable;
|
||||
import io.reactivex.ObservableTransformer;
|
||||
|
||||
import java.time.LocalDate;
|
||||
import java.util.List;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
|
||||
|
||||
public class OperatorsExample {
|
||||
private static final Logger logger = LoggerFactory.getLogger(OperatorsExample.class);
|
||||
|
||||
public static void main(String[] args) {
|
||||
var persons = List.of(
|
||||
new Person("John", "Dow", "male", LocalDate.of(1992, 3, 12)),
|
||||
new Person("Jane", "Dow", "female", LocalDate.of(2001, 6, 23)),
|
||||
new Person("Howard", "Lovecraft", "male", LocalDate.of(1890, 8, 20)),
|
||||
new Person("Joanne", "Rowling", "female", LocalDate.of(1965, 6, 30)));
|
||||
|
||||
var disposable = Observable.fromIterable(persons)
|
||||
.filter(person -> person.birth().isAfter(LocalDate.of(1990, 1, 1)))
|
||||
.map(p -> p.firstName() + " " + p.lastName())
|
||||
.toList()
|
||||
.subscribe(item -> logger.info("item: {}", item));
|
||||
|
||||
logger.info("disposable.isDisposed:{}", disposable.isDisposed());
|
||||
|
||||
var disposableTransform = Observable.fromIterable(persons)
|
||||
.compose(filterAndUpperCase())
|
||||
.subscribe(val -> logger.info("value:{}", val));
|
||||
|
||||
logger.info("disposable.isDisposed:{}", disposableTransform.isDisposed());
|
||||
}
|
||||
|
||||
private static ObservableTransformer<Person, String> filterAndUpperCase() {
|
||||
return upstream -> upstream
|
||||
.map(Person::firstName)
|
||||
.filter(s -> s.length() >= 4)
|
||||
.map(String::toUpperCase);
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,6 @@
|
||||
package ru.otus;
|
||||
|
||||
import java.time.LocalDate;
|
||||
|
||||
public record Person(String firstName, String lastName, String gender, LocalDate birth) {
|
||||
}
|
||||
@@ -0,0 +1,53 @@
|
||||
package ru.otus;
|
||||
|
||||
import io.reactivex.Observable;
|
||||
import io.reactivex.ObservableOnSubscribe;
|
||||
import io.reactivex.subjects.PublishSubject;
|
||||
import java.util.concurrent.Executors;
|
||||
import java.util.concurrent.TimeUnit;
|
||||
import java.util.concurrent.atomic.AtomicLong;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
|
||||
public class PublisherExample {
|
||||
private static final Logger logger = LoggerFactory.getLogger(PublisherExample.class);
|
||||
|
||||
public static void main(String[] args) throws Exception {
|
||||
publisherExample();
|
||||
}
|
||||
|
||||
public static void publisherExample() throws InterruptedException {
|
||||
Observable<String> ob = magicPublisher();
|
||||
logger.info("First subscribed");
|
||||
Thread.sleep(5000);
|
||||
var disposable1 = ob.subscribe(item -> logger.info("item: {}", item));
|
||||
|
||||
logger.info("disposable1.isDisposed:{}", disposable1.isDisposed());
|
||||
Thread.sleep(5000);
|
||||
|
||||
logger.info("Second subscribed");
|
||||
var disposable2 = ob.subscribe(item -> logger.info("item second: {}", item));
|
||||
|
||||
|
||||
logger.info("disposable2.isDisposed():{}", disposable2.isDisposed());
|
||||
|
||||
Thread.sleep(60_000);
|
||||
}
|
||||
|
||||
public static Observable<String> magicPublisher() {
|
||||
var executor = Executors.newSingleThreadScheduledExecutor();
|
||||
|
||||
ObservableOnSubscribe<Long> handler = emitter -> {
|
||||
var currentValue = new AtomicLong(0);
|
||||
executor.scheduleWithFixedDelay(() ->
|
||||
emitter.onNext(currentValue.incrementAndGet()), 0, 2, TimeUnit.SECONDS);
|
||||
};
|
||||
|
||||
Observable<String> obs = Observable.create(handler)
|
||||
.map(String::valueOf);
|
||||
|
||||
PublishSubject<String> subject = PublishSubject.create();
|
||||
obs.subscribe(subject);
|
||||
return subject;
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user