L20 rxJava

This commit is contained in:
sergey
2022-11-16 09:23:19 +03:00
parent f3e8ef8b7a
commit a19253125c
6 changed files with 300 additions and 0 deletions
+7
View File
@@ -0,0 +1,7 @@
.idea/
*.iml
target/
/node_modules
/output
+39
View File
@@ -0,0 +1,39 @@
<?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>2.2.4.RELEASE</version>
</parent>
<properties>
<maven.compiler.source>11</maven.compiler.source>
<maven.compiler.target>11</maven.compiler.target>
</properties>
<dependencies>
<dependency>
<groupId>io.reactivex.rxjava2</groupId>
<artifactId>rxjava</artifactId>
</dependency>
<dependency>
<groupId>ch.qos.logback</groupId>
<artifactId>logback-classic</artifactId>
<version>1.2.11</version>
</dependency>
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-api</artifactId>
<version>1.7.36</version>
</dependency>
</dependencies>
</project>
@@ -0,0 +1,75 @@
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 creatorExample() {
Observable<String> obs = createExample();
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());
}
private static void lazyObservable() {
Observable<String> obs = deferExample();
obs.doOnNext(item -> logger.info("item_1:{}", item))
.subscribe();
obs.doOnNext(item -> logger.info("item_2:{}", item))
.subscribe();
}
private static void onEachNext() {
Observable<String> obs = justExample();
obs.doOnEach(item -> logger.info("item_1:{}", item.getValue()))
.subscribe();
obs.doOnNext(item -> logger.info("item_2:{}", item))
.map(String::length)
.doOnNext(item -> logger.info("length_2:{}", item))
.subscribe();
}
private static Observable<String> justExample() {
return Observable.just("one", "two", "three");
}
private static Observable<String> deferExample() {
return Observable.defer(() -> {
logger.info("creating new Observable");
return Observable.just("one", "two", "three");
});
}
private static Observable<String> createExample() {
return Observable.create(emitter -> {
emitter.onNext("one");
emitter.onNext("two");
emitter.onError(new RuntimeException("Error!"));
emitter.onNext("three");
emitter.onComplete();
});
}
}
@@ -0,0 +1,44 @@
package ru.otus;
import io.reactivex.Emitter;
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.getBirth().isAfter(LocalDate.of(1990, 1, 1)))
.map(p -> p.getFirstName() + " " + p.getLastName())
.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::getFirstName)
.filter(s -> s.length() >= 4)
.map(String::toUpperCase);
}
}
@@ -0,0 +1,66 @@
package ru.otus;
import java.time.LocalDate;
import java.util.Objects;
public class Person {
private String firstName;
private String lastName;
private String gender;
private LocalDate birth;
public Person(String firstName, String lastName, String gender, LocalDate birth) {
this.firstName = firstName;
this.lastName = lastName;
this.gender = gender;
this.birth = birth;
}
public String getFirstName() {
return firstName;
}
public void setFirstName(String firstName) {
this.firstName = firstName;
}
public String getLastName() {
return lastName;
}
public void setLastName(String lastName) {
this.lastName = lastName;
}
public String getGender() {
return gender;
}
public void setGender(String gender) {
this.gender = gender;
}
public LocalDate getBirth() {
return birth;
}
public void setBirth(LocalDate birth) {
this.birth = birth;
}
@Override
public boolean equals(Object o) {
if (this == o) return true;
if (o == null || getClass() != o.getClass()) return false;
Person person = (Person) o;
return Objects.equals(firstName, person.firstName) &&
Objects.equals(lastName, person.lastName) &&
Objects.equals(gender, person.gender) &&
Objects.equals(birth, person.birth);
}
@Override
public int hashCode() {
return Objects.hash(firstName, lastName, gender, birth);
}
}
@@ -0,0 +1,69 @@
package ru.otus;
import io.reactivex.Observable;
import io.reactivex.Scheduler;
import io.reactivex.schedulers.Schedulers;
import io.reactivex.subjects.PublishSubject;
import java.util.concurrent.TimeUnit;
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");
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: {}", item));
logger.info("disposable2.isDisposed():{}", disposable2.isDisposed());
Thread.sleep(60_000);
}
public static Observable<String> magicPublisher() {
// Random r = new Random(1);
// AtomicInteger i = new AtomicInteger();
Scheduler scheduler = Schedulers.newThread();
PublishSubject<String> subject = PublishSubject.create();
var obs = Observable
.generate(() -> 0, (prev, emitter) -> {
var nextVal = prev + 1;
emitter.onNext(nextVal);
return nextVal;
})
.subscribeOn(scheduler)
.concatMap(i-> Observable.just(i).delay(2, TimeUnit.SECONDS))
.map(String::valueOf);
obs.subscribe(subject);
return subject;
// BehaviorSubject<String> subject = BehaviorSubject.create();
// AsyncSubject<String> subject = AsyncSubject.create();
// CompletableFuture.runAsync(() -> {
// try {
// Thread.sleep(7000);
// } catch (InterruptedException e) {
// e.printStackTrace();
// }
// subject.onComplete();
// });
// ReplaySubject<String> subject = ReplaySubject.create();
}
}