parallel programming with omnithreadlibrary primož gabrijelčič

Post on 14-Dec-2015

267 Views

Category:

Documents

7 Downloads

Preview:

Click to see full reader

TRANSCRIPT

Parallel Programming with OmniThreadLibraryPrimož Gabrijelčič

Primož Gabrijelčič

programmer, consultant, speaker, trainer

Delphi / Smart Mobile Studio

Email: primoz@gabrijelcic.orgTwitter: @thedelphigeekSkype: gabr42

The Delphi Geek – http://www.thedelphigeek.comSmart Programmer – http://www.smartprogrammer.org

What is OmniThreadLibrary?

OmniThreadLibrary is …

• … VCL for multithreading• … released under an open license• … actively developed• … frequently used• … available in Delphis from 2007 to XE3– Windows 32- or 64-bit, VCL only

How do I learn more?

OmniThreadLibrary on the web

• Home: otl.17slon.com• Code: omnithreadlibrary.googlecode.com• Book: leanpub.com/omnithreadlibrary• Wiki: otl.17slon.com/book• Support: otl.17slon.com/forum

How do I execute long operation in background

and run some code in the main thread after the

long operation has finished?

Async/Await

Initialization

Cleanup

Long operation

How do I run long calculation in background and

process the result in the main thread?

Future

Use result

Long calculation

How do I run same background operation in

multiple simultaneous copies processing an

input?

Background Worker

Data

Process

Result

Process Process

Process Process

How do I parallelize a process that executes in

multiple stages?

Pipeline

Data

Stage 1

Result

Stage 2Stage 3Stage 4

How do I work with databases in multithreaded

environment?

Databases

GUI

Database AccessFrame

Frame

Questions?

top related