Reactive extensions

28
Reactive Extensions “democratize cloud” Dima Pasko

description

Dmitry Pasko speech at Ciklum .NET Saturday (Kharkov 21.05.2011)

Transcript of Reactive extensions

Page 1: Reactive extensions

Reactive Extensions“democratize cloud”

Dima Pasko

Page 2: Reactive extensions

about me

Kharkov – Ciklum (Scale Point) - .NET – podcasts – open source

http://flavors.me/dimapasko

Page 3: Reactive extensions

Erik MeijerProfessor at Utrecht

UniversityOne of the designers

of HaskellMicrosoft Architect LINQVoltaRx

Page 4: Reactive extensions

Rx mission“Rx is a library for composing

asynchronous and event-based programs using observable collections.”

Page 5: Reactive extensions

Rx current version• Base interfaces in BCL .NET 4• Stable version: v1.0.10425• Experimental Release: v1.1.10425• Last update: April 28, 2011• http://msdn.microsoft.com/en-us/

data/gg577609

Page 6: Reactive extensions

Rx for.NET

.NET 3.5 .NET 4

Silverlight Silverlight 3 Silverlight 4 Windows Phone

Java script

Page 7: Reactive extensions

“asynchronous”

Page 8: Reactive extensions

“observable”interface IEnumerable<out T>{ IEnumerator<T> GetEnumerator();}

interface IEnumerator<out T> : IDisposable{ bool MoveNext(); T Current { get; } void Reset();}

interface IObservable<out T>{ IDisposable Subscribe(IObserver<T> observer);}

interface IObserver<in T>{ void OnNext(T value); void OnError(Exception ex); void OnCompleted();}

Page 9: Reactive extensions

Environment

MoveN

ex

tGot next?

Application

On

Next

Have next!

IEnumerable<T>

IEnumerator<T>

IObservable<T>

IObserver<T>

Inte

racti

ve R

eactiv

e

Page 10: Reactive extensions

IDisposableinterface IObservable<out T>{ IDisposable Subscribe(IObserver<T> observer);}

interface IObserver<in T>{ void OnNext(T value); void OnError(Exception ex); void OnCompleted();}

Page 11: Reactive extensions

demo #1Simple example

Page 12: Reactive extensions

exception handlingObservable.Catch()

Observable.Throw()Observable.Retry()Observable.Timeout()

Page 13: Reactive extensions

demo #2Exception handling

Page 14: Reactive extensions

“composing”• Linq(Where, Take, Skip, Sum, Max,

Any, …)• Statements(If, Case, For, While,

DoWhile)• Combinators(Merge, Zip, Amb, …)• Exceptions(Catch, Retry, ..)• Rx(Delay, Throttle, Interval, Publish,

…)

Page 15: Reactive extensions

“event-based”Observable.FromEventPattern()Observable.FromAsyncEventPattern()

Page 16: Reactive extensions

ISchedulerObservable.OnserveOn()Observable.SubscribeOn(Scheduler.Tas

kPool)

Page 17: Reactive extensions

demo #3Big demo!!!

Page 18: Reactive extensions

Rx unit testing

Page 19: Reactive extensions

more RxRx Contrib

http://rxcontrib.codeplex.com/ Reactive Extensions - Extensions (Rxx)

http://rxx.codeplex.com/ Rx Power Toys

http://rxpowertoys.codeplex.com/

Page 20: Reactive extensions

examples

Page 21: Reactive extensions

ReactiveUI

http://www.reactiveui.net/

Page 22: Reactive extensions

domain events

http://chaliy.name/archive/2010/1/business_logic_rx_example

Page 23: Reactive extensions

TweetSharp.Rx

https://github.com/jhollingworth/TweetSharp.Rx

Page 24: Reactive extensions

Rx in books

Page 25: Reactive extensions

out of scope• Hot&Cold• Marble diagrams• Linq2PowerShell, Linq2WMI• IQbservable<T>

(IQueryable<T> + IObservable<T>)

• ISubject, Subject<T>• ReactiveJS

Page 26: Reactive extensions

informationRx team blog

http://blogs.msdn.com/rxteamDevLabs

http://msdn.microsoft.com/en-us/devlabs/ee794896.aspxMSDN forums

http://social.msdn.microsoft.com/Forums/en-US/rxChannel9

http://channel9.msdn.com/Tags/RxWiki

http://rxwiki.wikidot.com

Page 27: Reactive extensions

summary

Page 28: Reactive extensions

[email protected]@ciklum.net

@dimapasko