SlideShare a Scribd company logo
1 of 71
@FMuntenescu
Florina Muntenescu
@FMuntenescu
Building a
Reactive Mindset
@FMuntenescu
Florina Muntenescu
@FMuntenescu
Building a
Reactive Mindset
@FMuntenescu
Donald
Duck’s Burger
Joint
@FMuntenescu
Huey Dewey Louie
@FMuntenescu
Huey
@FMuntenescu
Dewey
@FMuntenescu
Louie
@FMuntenescu
Huey
Dewey
Louie
@FMuntenescu
filter(meat -> isMeatFresh(meat))
map(meat -> cook(meat))
Dewey
@FMuntenescu
zip
@FMuntenescu
zip
@FMuntenescu
zip
@FMuntenescu
zip
@FMuntenescu
STREAMS OF DATA
@FMuntenescu
STREAMS OF DATA
@FMuntenescu
STREAMS OF DATA
@FMuntenescu
zip
STREAMS OF DATA
@FMuntenescu
Consumer
Observable
Subscriber
@FMuntenescu
filter(meat -> isMeatFresh(meat))
map(meat -> cook(meat))
operators
@FMuntenescu
Huey.getBun()
@FMuntenescu
filter(meat -> isMeatFresh(meat))
for(Meat meat: meatList){
if(!isMeatFresh(meat)){
meatList.remove(meat);
}
}
@FMuntenescu
Observable.from(meatSource)
.filter(meat ->
isMeatFresh(meat))
filter(meat -> isMeatFresh(meat))
@FMuntenescu
filter(meat -> isMeatFresh(meat))
map(meat -> cook(meat))
for(Meat meat: meatList){
meat = cook(meat);
}
@FMuntenescu
Observable.from(meatSource)
.filter(meat ->
isMeatGoneBad(meat))
.map(meat -> cook(meat));
filter(meat -> isMeatFresh(meat))
map(meat -> cook(meat))
@FMuntenescu
Observable<Burger> burgerObservable =
Observable.zip(bunObservable,
meatObservable,
tomatoObservable,
(bun, meat, tomato) ->
makeBurger(bun, meat, tomato))
bunObservable
meatObservable
tomatoObservable
burgerObservable
@FMuntenescu
Observable<Burger> burgerObservable =
Observable.zip(bunObservable,
meatObservable,
tomatoObservable,
(bun, meat, tomato) ->
makeBurger(bun, meat, tomato))
bunObservable
meatObservable
tomatoObservable
burgerObservable
@FMuntenescu
Consumer
Observable
Subscriber
.subscribe
@FMuntenescu
Subscriber
burgerObservable
.subscribe(mickeySubscriber);
@FMuntenescu
Subscriber
onNext(Burger burger)
onCompleted()
burgerObservable
.subscribe(
burger -> eatBurger(burger),
error -> complain(error),
() -> leaveBurgerJoint());
// onNext
//onError
//onCompleted
onError(Throwable error)
@FMuntenescu
Observable.zip(bunObservable,
meatObservable,
tomatoObservable,
(bun, meat, tomato) ->
makeBurger(bun, meat, tomato))
.subscribe(burger -> eatBurger(burger),
error -> complain(error));
// dining area
// dining area
@FMuntenescu
// kitchen
Observable.zip(bunObservable,
meatObservable,
tomatoObservable,
(bun, meat, tomato) ->
makeBurger(bun, meat, tomato))
.subscribe(burger -> eatBurger(burger),
error -> complain(error));
// dining area
@FMuntenescu
// kitchen
// dining area
Observable.zip(bunObservable,
meatObservable,
tomatoObservable,
(bun, meat, tomato) ->
makeBurger(bun, meat, tomato))
.subscribeOn(kitchen)
.observeOn(dining area)
.subscribe(burger -> eatBurger(burger),
error -> complain(error));
@FMuntenescu
Observable.zip(bunObservable,
meatObservable,
tomatoObservable,
(bun, meat, tomato) ->
makeBurger(bun, meat, tomato))
.subscribeOn(Schedulers.computation())
.observeOn(AndroidSchedulers.mainThread())
.subscribe(burger -> eatBurger(burger),
error -> complain(error));
// kitchen
// dining area
@FMuntenescu
Stream of data
Observable
Subscriber
Operators
Threads
@FMuntenescu
Creating
Observables
@FMuntenescu
Creating
Observables
From a
List
@FMuntenescu
List<Burger> burgers = new ArrayList<>();
burgers.add(new Burger());
burgers.add(new Burger());
Observable<Burger> burgerObservable =
Observable.from(burgers);
@FMuntenescu
List<Burger> burgers = new ArrayList<>();
burgers.add(new Burger());
burgers.add(new Burger());
Observable<Burger> burgerObservable =
Observable.from(burgers);
1 2
@FMuntenescu
Observable<Burger> burgerObservable =
Observable.from(burgers);
burgerObservable.subscribe(new Subscriber<Burger>() {
@Override
public void onNext(final Burger burger) {
}
@Override
public void onCompleted() {
}
@Override
public void onError(final Throwable e) {
}
});
@FMuntenescu
Observable<Burger> burgerObservable = Observable.from(burgers);
burgerObservable.subscribe(new Subscriber<Burger>() {
@Override
public void onNext(final Burger burger) {
// handle burger 1
}
@Override
public void onCompleted() {
}
@Override
public void onError(final Throwable e) {
}
});
1
@FMuntenescu
Observable<Burger> burgerObservable = Observable.from(burgers);
burgerObservable.subscribe(new Subscriber<Burger>() {
@Override
public void onNext(final Burger burger) {
// handle burger 2
}
@Override
public void onCompleted() {
}
@Override
public void onError(final Throwable e) {
}
});
1 2
@FMuntenescu
Observable<Burger> burgerObservable = Observable.from(burgers);
burgerObservable.subscribe(new Subscriber<Burger>() {
@Override
public void onNext(final Burger burger) {
}
@Override
public void onCompleted() {
// no more burgers!
}
@Override
public void onError(final Throwable e) {
}
});
1 2
@FMuntenescu
Observable<List<Burger>>
List<Burger> burgers = new ArrayList<>();
burgers.add(new Burger());
burgers.add(new Burger());
burgerObservable =
Observable.just(burgers);
@FMuntenescu
1
Observable<List<Burger>> burgerObservable
=
Observable.just(burgers);
List<Burger> burgers = new ArrayList<>();
burgers.add(new Burger());
burgers.add(new Burger());
@FMuntenescu
Observable<List<Burger>> burgerObservable =
Observable.just(burgers);
burgerObservable.subscribe(
new Subscriber<List<Burger>>() {
@Override
public void onNext(final List<Burger> burgers) {
}
@Override
public void onCompleted() {
}
@Override
public void onError(final Throwable e) {
}
});
@FMuntenescu
Observable<List<Burger>> burgerObservable =
Observable.just(burgers);
burgerObservable.subscribe(
new Subscriber<List<Burger>>() {
@Override
public void onNext(
final List<Burger> burgers) {
// handle the list of burgers
}
@Override
public void onCompleted() {
}
@Override
public void onError(final Throwable e) {
}
});
1
@FMuntenescu
Observable<List<Burger>> burgerObservable =
Observable.just(burgers);
burgerObservable.subscribe(
new Subscriber<List<Burger>>() {
@Override
public void onNext(
final List<Burger> burgers) {
// handle the list of burgers
}
@Override
public void onCompleted() {
// no more burgers!
}
@Override
public void onError(final Throwable e) {
}
});
1
@FMuntenescu
Creating
Observables
From
Click
Events
@FMuntenescu
@FMuntenescu
@FMuntenescu
@FMuntenescu
[click!] [click!] [click!]
@FMuntenescu
???.subscribe(new Subscriber<String>() {
@Override
public void onNext(final String s) {
// called on every click
}
@Override
public void onCompleted() {
}
@Override
public void onError(final Throwable e) {
}
});
@FMuntenescu
[click!] [click!] [click!]
???.onNext(…) ???.onNext(…) ???.onNext(…)
@FMuntenescu
burgerButton.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(final View view) {
}
});
PublishSubject<String> burgerRequestedSubject =
PublishSubject.create();
@FMuntenescu
burgerButton.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(final View view) {
burgerRequestedSubject.onNext(…);
}
});
PublishSubject<String> burgerRequestedSubject =
PublishSubject.create();
@FMuntenescu
burgerRequestedSubject.subscribe(new Subscriber<String>() {
@Override
public void onNext(final String s) {
// called on every click
}
@Override
public void onCompleted() {
// will never be called for click events
}
@Override
public void onError(final Throwable e) {
}
});
@FMuntenescu
Creating
Observables
From
Declarativ
e Code
@FMuntenescu
public Burger cook(){
// cooking is time consuming
return burger;
}
Observable<Burger> burgerObservable =
Observable.fromCallable(this::cook);
@FMuntenescu
Error
Handling
@FMuntenescu
Thread t = new Thread(new Runnable() {
@Override
public void run() {
cook();
}
});
@FMuntenescu
Thread t = new Thread(new Runnable() {
@Override
public void run() {
try{
cook();
} catch(Exception e) {
// handle exception
}
}
});
@FMuntenescu
getMeatObservable()
.filter(meat -> isMeatFresh(meat))
.map(meat -> cook(meat))
.subscribeOn(
meat -> doSomething(),
error -> complain(error));
@FMuntenescu
getMeatObservable()
.filter(meat -> isMeatFresh(meat))
.map(meat -> cook(meat))
.subscribeOn(
meat -> doSomething(),
error -> complain(error));
@FMuntenescu
public Observable<Meat> getCookedMeat() {
return getMeatObservable()
.filter(meat -> isMeatFresh(meat))
.map(meat -> cook(meat));
}
Observable.zip(getBun(),
getCookedMeat(),
getTomatoSlice(),
(bun, meat, tomato) ->
makeBurger(bun, meat, tomato))
.subscribeOn(
burger -> eatBurger(burger),
error -> complain(error));
@FMuntenescu
public Observable<Meat> getCookedMeat() {
return getMeatObservable()
.filter(meat -> isMeatFresh(meat))
.map(meat -> cook(meat));
}
Observable.zip(getBun(),
getCookedMeat(),
getTomatoSlice(),
(bun, meat, tomato) ->
makeBurger(bun, meat, tomato))
.subscribeOn(
burger -> eatBurger(burger),
error -> complain(error));
@FMuntenescu
Start using
RxJava
@FMuntenescu
public Burger cook(){
// cooking is time consuming
// make sure it’s on a background thread
return burger;
}
Observable<Burger> burgerObservable =
Observable.fromCallable(this::cook)
.subscribeOn(Schedulers.computation())
.observeOn(AndroidSchedulers.mainThread())
@FMuntenescu
@GET(“repos”)
Call<List<Burger>> repoBurgers();
@GET(“repos”)
Observable<List<Burger>> repoBurgers();
@FMuntenescu
@FMuntenescu@FMuntenescu
jobs@updudes.net
Building a Reactive Mindset
https://upday.github.io/blog/reactive_mindset_burgers
Reactive Burgers – Code Example
https://github.com/florina-muntenescu/ReactiveBurgers
Building a
Burger
Reactive
Mindset

More Related Content

Recently uploaded

CHEAP Call Girls in Pushp Vihar (-DELHI )🔝 9953056974🔝(=)/CALL GIRLS SERVICE
CHEAP Call Girls in Pushp Vihar (-DELHI )🔝 9953056974🔝(=)/CALL GIRLS SERVICECHEAP Call Girls in Pushp Vihar (-DELHI )🔝 9953056974🔝(=)/CALL GIRLS SERVICE
CHEAP Call Girls in Pushp Vihar (-DELHI )🔝 9953056974🔝(=)/CALL GIRLS SERVICE
9953056974 Low Rate Call Girls In Saket, Delhi NCR
 
+971565801893>>SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHAB...
+971565801893>>SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHAB...+971565801893>>SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHAB...
+971565801893>>SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHAB...
Health
 
CALL ON ➥8923113531 🔝Call Girls Kakori Lucknow best sexual service Online ☂️
CALL ON ➥8923113531 🔝Call Girls Kakori Lucknow best sexual service Online  ☂️CALL ON ➥8923113531 🔝Call Girls Kakori Lucknow best sexual service Online  ☂️
CALL ON ➥8923113531 🔝Call Girls Kakori Lucknow best sexual service Online ☂️
anilsa9823
 

Recently uploaded (20)

SyndBuddy AI 2k Review 2024: Revolutionizing Content Syndication with AI
SyndBuddy AI 2k Review 2024: Revolutionizing Content Syndication with AISyndBuddy AI 2k Review 2024: Revolutionizing Content Syndication with AI
SyndBuddy AI 2k Review 2024: Revolutionizing Content Syndication with AI
 
W01_panagenda_Navigating-the-Future-with-The-Hitchhikers-Guide-to-Notes-and-D...
W01_panagenda_Navigating-the-Future-with-The-Hitchhikers-Guide-to-Notes-and-D...W01_panagenda_Navigating-the-Future-with-The-Hitchhikers-Guide-to-Notes-and-D...
W01_panagenda_Navigating-the-Future-with-The-Hitchhikers-Guide-to-Notes-and-D...
 
CHEAP Call Girls in Pushp Vihar (-DELHI )🔝 9953056974🔝(=)/CALL GIRLS SERVICE
CHEAP Call Girls in Pushp Vihar (-DELHI )🔝 9953056974🔝(=)/CALL GIRLS SERVICECHEAP Call Girls in Pushp Vihar (-DELHI )🔝 9953056974🔝(=)/CALL GIRLS SERVICE
CHEAP Call Girls in Pushp Vihar (-DELHI )🔝 9953056974🔝(=)/CALL GIRLS SERVICE
 
The Real-World Challenges of Medical Device Cybersecurity- Mitigating Vulnera...
The Real-World Challenges of Medical Device Cybersecurity- Mitigating Vulnera...The Real-World Challenges of Medical Device Cybersecurity- Mitigating Vulnera...
The Real-World Challenges of Medical Device Cybersecurity- Mitigating Vulnera...
 
Unveiling the Tech Salsa of LAMs with Janus in Real-Time Applications
Unveiling the Tech Salsa of LAMs with Janus in Real-Time ApplicationsUnveiling the Tech Salsa of LAMs with Janus in Real-Time Applications
Unveiling the Tech Salsa of LAMs with Janus in Real-Time Applications
 
5 Signs You Need a Fashion PLM Software.pdf
5 Signs You Need a Fashion PLM Software.pdf5 Signs You Need a Fashion PLM Software.pdf
5 Signs You Need a Fashion PLM Software.pdf
 
A Secure and Reliable Document Management System is Essential.docx
A Secure and Reliable Document Management System is Essential.docxA Secure and Reliable Document Management System is Essential.docx
A Secure and Reliable Document Management System is Essential.docx
 
+971565801893>>SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHAB...
+971565801893>>SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHAB...+971565801893>>SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHAB...
+971565801893>>SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHAB...
 
Shapes for Sharing between Graph Data Spaces - and Epistemic Querying of RDF-...
Shapes for Sharing between Graph Data Spaces - and Epistemic Querying of RDF-...Shapes for Sharing between Graph Data Spaces - and Epistemic Querying of RDF-...
Shapes for Sharing between Graph Data Spaces - and Epistemic Querying of RDF-...
 
Unlocking the Future of AI Agents with Large Language Models
Unlocking the Future of AI Agents with Large Language ModelsUnlocking the Future of AI Agents with Large Language Models
Unlocking the Future of AI Agents with Large Language Models
 
HR Software Buyers Guide in 2024 - HRSoftware.com
HR Software Buyers Guide in 2024 - HRSoftware.comHR Software Buyers Guide in 2024 - HRSoftware.com
HR Software Buyers Guide in 2024 - HRSoftware.com
 
Right Money Management App For Your Financial Goals
Right Money Management App For Your Financial GoalsRight Money Management App For Your Financial Goals
Right Money Management App For Your Financial Goals
 
call girls in Vaishali (Ghaziabad) 🔝 >༒8448380779 🔝 genuine Escort Service 🔝✔️✔️
call girls in Vaishali (Ghaziabad) 🔝 >༒8448380779 🔝 genuine Escort Service 🔝✔️✔️call girls in Vaishali (Ghaziabad) 🔝 >༒8448380779 🔝 genuine Escort Service 🔝✔️✔️
call girls in Vaishali (Ghaziabad) 🔝 >༒8448380779 🔝 genuine Escort Service 🔝✔️✔️
 
CALL ON ➥8923113531 🔝Call Girls Kakori Lucknow best sexual service Online ☂️
CALL ON ➥8923113531 🔝Call Girls Kakori Lucknow best sexual service Online  ☂️CALL ON ➥8923113531 🔝Call Girls Kakori Lucknow best sexual service Online  ☂️
CALL ON ➥8923113531 🔝Call Girls Kakori Lucknow best sexual service Online ☂️
 
Steps To Getting Up And Running Quickly With MyTimeClock Employee Scheduling ...
Steps To Getting Up And Running Quickly With MyTimeClock Employee Scheduling ...Steps To Getting Up And Running Quickly With MyTimeClock Employee Scheduling ...
Steps To Getting Up And Running Quickly With MyTimeClock Employee Scheduling ...
 
Learn the Fundamentals of XCUITest Framework_ A Beginner's Guide.pdf
Learn the Fundamentals of XCUITest Framework_ A Beginner's Guide.pdfLearn the Fundamentals of XCUITest Framework_ A Beginner's Guide.pdf
Learn the Fundamentals of XCUITest Framework_ A Beginner's Guide.pdf
 
Reassessing the Bedrock of Clinical Function Models: An Examination of Large ...
Reassessing the Bedrock of Clinical Function Models: An Examination of Large ...Reassessing the Bedrock of Clinical Function Models: An Examination of Large ...
Reassessing the Bedrock of Clinical Function Models: An Examination of Large ...
 
Software Quality Assurance Interview Questions
Software Quality Assurance Interview QuestionsSoftware Quality Assurance Interview Questions
Software Quality Assurance Interview Questions
 
Short Story: Unveiling the Reasoning Abilities of Large Language Models by Ke...
Short Story: Unveiling the Reasoning Abilities of Large Language Models by Ke...Short Story: Unveiling the Reasoning Abilities of Large Language Models by Ke...
Short Story: Unveiling the Reasoning Abilities of Large Language Models by Ke...
 
Hand gesture recognition PROJECT PPT.pptx
Hand gesture recognition PROJECT PPT.pptxHand gesture recognition PROJECT PPT.pptx
Hand gesture recognition PROJECT PPT.pptx
 

Featured

How Race, Age and Gender Shape Attitudes Towards Mental Health
How Race, Age and Gender Shape Attitudes Towards Mental HealthHow Race, Age and Gender Shape Attitudes Towards Mental Health
How Race, Age and Gender Shape Attitudes Towards Mental Health
ThinkNow
 
Social Media Marketing Trends 2024 // The Global Indie Insights
Social Media Marketing Trends 2024 // The Global Indie InsightsSocial Media Marketing Trends 2024 // The Global Indie Insights
Social Media Marketing Trends 2024 // The Global Indie Insights
Kurio // The Social Media Age(ncy)
 

Featured (20)

2024 State of Marketing Report – by Hubspot
2024 State of Marketing Report – by Hubspot2024 State of Marketing Report – by Hubspot
2024 State of Marketing Report – by Hubspot
 
Everything You Need To Know About ChatGPT
Everything You Need To Know About ChatGPTEverything You Need To Know About ChatGPT
Everything You Need To Know About ChatGPT
 
Product Design Trends in 2024 | Teenage Engineerings
Product Design Trends in 2024 | Teenage EngineeringsProduct Design Trends in 2024 | Teenage Engineerings
Product Design Trends in 2024 | Teenage Engineerings
 
How Race, Age and Gender Shape Attitudes Towards Mental Health
How Race, Age and Gender Shape Attitudes Towards Mental HealthHow Race, Age and Gender Shape Attitudes Towards Mental Health
How Race, Age and Gender Shape Attitudes Towards Mental Health
 
AI Trends in Creative Operations 2024 by Artwork Flow.pdf
AI Trends in Creative Operations 2024 by Artwork Flow.pdfAI Trends in Creative Operations 2024 by Artwork Flow.pdf
AI Trends in Creative Operations 2024 by Artwork Flow.pdf
 
Skeleton Culture Code
Skeleton Culture CodeSkeleton Culture Code
Skeleton Culture Code
 
PEPSICO Presentation to CAGNY Conference Feb 2024
PEPSICO Presentation to CAGNY Conference Feb 2024PEPSICO Presentation to CAGNY Conference Feb 2024
PEPSICO Presentation to CAGNY Conference Feb 2024
 
Content Methodology: A Best Practices Report (Webinar)
Content Methodology: A Best Practices Report (Webinar)Content Methodology: A Best Practices Report (Webinar)
Content Methodology: A Best Practices Report (Webinar)
 
How to Prepare For a Successful Job Search for 2024
How to Prepare For a Successful Job Search for 2024How to Prepare For a Successful Job Search for 2024
How to Prepare For a Successful Job Search for 2024
 
Social Media Marketing Trends 2024 // The Global Indie Insights
Social Media Marketing Trends 2024 // The Global Indie InsightsSocial Media Marketing Trends 2024 // The Global Indie Insights
Social Media Marketing Trends 2024 // The Global Indie Insights
 
Trends In Paid Search: Navigating The Digital Landscape In 2024
Trends In Paid Search: Navigating The Digital Landscape In 2024Trends In Paid Search: Navigating The Digital Landscape In 2024
Trends In Paid Search: Navigating The Digital Landscape In 2024
 
5 Public speaking tips from TED - Visualized summary
5 Public speaking tips from TED - Visualized summary5 Public speaking tips from TED - Visualized summary
5 Public speaking tips from TED - Visualized summary
 
ChatGPT and the Future of Work - Clark Boyd
ChatGPT and the Future of Work - Clark Boyd ChatGPT and the Future of Work - Clark Boyd
ChatGPT and the Future of Work - Clark Boyd
 
Getting into the tech field. what next
Getting into the tech field. what next Getting into the tech field. what next
Getting into the tech field. what next
 
Google's Just Not That Into You: Understanding Core Updates & Search Intent
Google's Just Not That Into You: Understanding Core Updates & Search IntentGoogle's Just Not That Into You: Understanding Core Updates & Search Intent
Google's Just Not That Into You: Understanding Core Updates & Search Intent
 
How to have difficult conversations
How to have difficult conversations How to have difficult conversations
How to have difficult conversations
 
Introduction to Data Science
Introduction to Data ScienceIntroduction to Data Science
Introduction to Data Science
 
Time Management & Productivity - Best Practices
Time Management & Productivity -  Best PracticesTime Management & Productivity -  Best Practices
Time Management & Productivity - Best Practices
 
The six step guide to practical project management
The six step guide to practical project managementThe six step guide to practical project management
The six step guide to practical project management
 
Beginners Guide to TikTok for Search - Rachel Pearson - We are Tilt __ Bright...
Beginners Guide to TikTok for Search - Rachel Pearson - We are Tilt __ Bright...Beginners Guide to TikTok for Search - Rachel Pearson - We are Tilt __ Bright...
Beginners Guide to TikTok for Search - Rachel Pearson - We are Tilt __ Bright...
 

Building a reactive mindset

Editor's Notes

  1. In ReactiveX, you're not pulling values - you're not telling Paco to give you a bun! but you get values pushed – Paco gives you buns and then you act on the emissions of that stream.
  2. For example, when we need to filter the meat that has gone bad, we don't have an for(meat: meatBunch)
  3. but rather, we say that from this stream of meat balls we only want those that are good. We shouldn't received the meat that has gone bad.
  4. The concepts are still the same - streams of data that are fairly easy to manipulate and to compose, at the same time, being able to handle the working threads.