SlideShare une entreprise Scribd logo
1  sur  47
Télécharger pour lire hors ligne
C++11 Concurrency Tutorial
Anthony Williams
Just Software Solutions Ltd
http://www.justsoftwaresolutions.co.uk

28th April 2012
C++11 Concurrency Tutorial

Asynchronous tasks and
threads
Promises and tasks
Mutexes and condition
variables
Atomics
Anthony Williams
C++11 Concurrency Tutorial

Just Software Solutions Ltd http://www.justsoftwaresolutions.co.uk
Spawning asynchronous tasks
Spawning asynchronous tasks

Two ways: std::async and
std::thread
It’s all about things that are
Callable:
Functions and Member functions
Objects with operator() and Lambda
functions
Anthony Williams
C++11 Concurrency Tutorial

Just Software Solutions Ltd http://www.justsoftwaresolutions.co.uk
Hello World with std::async
#include <future> // for std::async
#include <iostream>
void write_message(std::string const& message) {
std::cout<<message;
}
int main() {
auto f=std::async(write_message,
"hello world from std::asyncn");
write_message("hello world from mainn");
f.wait();
}

Anthony Williams
C++11 Concurrency Tutorial

Just Software Solutions Ltd http://www.justsoftwaresolutions.co.uk
Hello World with std::thread
#include <thread> // for std::thread
#include <iostream>
void write_message(std::string const& message) {
std::cout<<message;
}
int main() {
std::thread t(write_message,
"hello world from std::threadn");
write_message("hello world from mainn");
t.join();
}

Anthony Williams
C++11 Concurrency Tutorial

Just Software Solutions Ltd http://www.justsoftwaresolutions.co.uk
Missing join with std::thread
#include <thread>
#include <iostream>
void write_message(std::string const& message) {
std::cout<<message;
}
int main() {
std::thread t(write_message,
"hello world from std::threadn");
write_message("hello world from mainn");
// oops no join
}

Anthony Williams
C++11 Concurrency Tutorial

Just Software Solutions Ltd http://www.justsoftwaresolutions.co.uk
Missing wait with std::async
#include <future>
#include <iostream>
void write_message(std::string const& message) {
std::cout<<message;
}
int main() {
auto f=std::async(write_message,
"hello world from std::asyncn");
write_message("hello world from mainn");
// oops no wait
}

Anthony Williams
C++11 Concurrency Tutorial

Just Software Solutions Ltd http://www.justsoftwaresolutions.co.uk
Async Launch Policies

The standard launch policies are the
members of the std::launch scoped
enum.
They can be used individually or together.

Anthony Williams
C++11 Concurrency Tutorial

Just Software Solutions Ltd http://www.justsoftwaresolutions.co.uk
Async Launch Policies

std::launch::async => “as if” in a new
thread.
std::launch::deferred => executed on
demand.
std::launch::async |
std::launch::deferred =>
implementation chooses (default).

Anthony Williams
C++11 Concurrency Tutorial

Just Software Solutions Ltd http://www.justsoftwaresolutions.co.uk
std::launch::async
#include <future>
#include <iostream>
#include <stdio.h>
void write_message(std::string const& message) {
std::cout<<message;
}
int main() {
auto f=std::async(
std::launch::async,write_message,
"hello world from std::asyncn");
write_message("hello world from mainn");
getchar(); f.wait();
}
Anthony Williams
C++11 Concurrency Tutorial

Just Software Solutions Ltd http://www.justsoftwaresolutions.co.uk
std::launch::deferred
#include <future>
#include <iostream>
#include <stdio.h>
void write_message(std::string const& message) {
std::cout<<message;
}
int main() {
auto f=std::async(
std::launch::deferred,write_message,
"hello world from std::asyncn");
write_message("hello world from mainn");
getchar(); f.wait();
}
Anthony Williams
C++11 Concurrency Tutorial

Just Software Solutions Ltd http://www.justsoftwaresolutions.co.uk
Returning values with std::async

#include <future>
#include <iostream>
int find_the_answer() {
return 42;
}
int main() {
auto f=std::async(find_the_answer);
std::cout<<"the answer is "<<f.get()<<"n";
}

Anthony Williams
C++11 Concurrency Tutorial

Just Software Solutions Ltd http://www.justsoftwaresolutions.co.uk
Passing parameters
#include <future>
#include <iostream>
std::string copy_string(std::string const&s) {
return s;
}
int main() {
std::string s="hello";
auto f=std::async(std::launch::deferred,
copy_string,s);
s="goodbye";
std::cout<<f.get()<<" world!n";
}
Anthony Williams
C++11 Concurrency Tutorial

Just Software Solutions Ltd http://www.justsoftwaresolutions.co.uk
Passing parameters with std::ref
#include <future>
#include <iostream>
std::string copy_string(std::string const&s) {
return s;
}
int main() {
std::string s="hello";
auto f=std::async(std::launch::deferred,
copy_string,std::ref(s));
s="goodbye";
std::cout<<f.get()<<" world!n";
}
Anthony Williams
C++11 Concurrency Tutorial

Just Software Solutions Ltd http://www.justsoftwaresolutions.co.uk
Passing parameters with a lambda
std::string copy_string(std::string const&s) {
return s;
}
int main() {
std::string s="hello";
auto f=std::async(std::launch::deferred,
[&s](){return copy_string(s);});
s="goodbye";
std::cout<<f.get()<<" world!n";
}

Anthony Williams
C++11 Concurrency Tutorial

Just Software Solutions Ltd http://www.justsoftwaresolutions.co.uk
std::async passes exceptions

#include <future>
#include <iostream>
int find_the_answer() {
throw std::runtime_error("Unable to find the answe
}
int main() {
auto f=std::async(find_the_answer);
try {
std::cout<<"the answer is "<<f.get()<<"n";
}
catch(std::runtime_error const& e) {
std::cout<<"nCaught exception: "<<e.what()<<std
}
}
Anthony Williams
C++11 Concurrency Tutorial

Just Software Solutions Ltd http://www.justsoftwaresolutions.co.uk
Promises and Tasks
Manually setting futures

Two ways: std::promise and
std::packaged_task
std::promise allows you to explicitly set
the value
std::packaged_task is for manual task
invocation, e.g. thread pools.

Anthony Williams
C++11 Concurrency Tutorial

Just Software Solutions Ltd http://www.justsoftwaresolutions.co.uk
std::promise
#include <future>
#include <thread>
#include <iostream>
void find_the_answer(std::promise<int>* p) {
p->set_value(42);
}
int main() {
std::promise<int> p;
auto f=p.get_future();
std::thread t(find_the_answer,&p);
std::cout<<"the answer is "<<f.get()<<"n";
t.join();
}
Anthony Williams
C++11 Concurrency Tutorial

Just Software Solutions Ltd http://www.justsoftwaresolutions.co.uk
std::packaged_task
#include <future>
#include <thread>
#include <iostream>
int find_the_answer() {
return 42;
}
int main() {
std::packaged_task<int()> task(find_the_answer);
auto f=task.get_future();
std::thread t(std::move(task));
std::cout<<"the answer is "<<f.get()<<"n";
t.join();
}
Anthony Williams
C++11 Concurrency Tutorial

Just Software Solutions Ltd http://www.justsoftwaresolutions.co.uk
Waiting for futures from multiple threads
Use std::shared_future<T> rather than
std::future<T>
std::future<int> f=/*...*/;
std::shared_future<int> sf(std::move(f));
std::future<int> f2=/*...*/;
std::shared_future<int> sf2(f.share());
std::promise<int> p;
std::shared_future<int> sf3(p.get_future());

Anthony Williams
C++11 Concurrency Tutorial

Just Software Solutions Ltd http://www.justsoftwaresolutions.co.uk
#include <future>
#include <thread>
#include <iostream>
#include <sstream>
void wait_for_notify(int id,std::shared_future<int> sf)
std::ostringstream os;
os<<"Thread "<<id<<" waitingn";
std::cout<<os.str(); os.str("");
os<<"Thread "<<id<<" woken, val="<<sf.get()<<"n";
std::cout<<os.str();
}
int main() {
std::promise<int> p;
auto sf=p.get_future().share();
std::thread t1(wait_for_notify,1,sf);
std::thread t2(wait_for_notify,2,sf);
std::cout<<"Waitingn"; std::cin.get();
p.set_value(42);
t2.join(); t1.join();
}
std::shared_future<T> objects cannot be shared

Anthony Williams
C++11 Concurrency Tutorial

Just Software Solutions Ltd http://www.justsoftwaresolutions.co.uk
Separate std::shared_future<T> objects can
share state

Anthony Williams
C++11 Concurrency Tutorial

Just Software Solutions Ltd http://www.justsoftwaresolutions.co.uk
Mutexes and Condition Variables
Lower level synchronization

Locks and Mutexes
Condition variables

Anthony Williams
C++11 Concurrency Tutorial

Just Software Solutions Ltd http://www.justsoftwaresolutions.co.uk
Mutexes

C++11 has 4 mutex classes:
std::mutex
std::recursive_mutex
std::timed_mutex
std::recursive_timed_mutex

Anthony Williams
C++11 Concurrency Tutorial

Just Software Solutions Ltd http://www.justsoftwaresolutions.co.uk
Mutex operations (I)

Mutexes have 3 basic operations, which form
the Lockable concept:
m.lock()
m.try_lock()
m.unlock()

Anthony Williams
C++11 Concurrency Tutorial

Just Software Solutions Ltd http://www.justsoftwaresolutions.co.uk
Mutex operations (II)

“Timed” mutexes have 2 additional operations.
A Lockable type that provides them satisfies
the TimedLockable concept.
m.try_lock_for(duration)
m.try_lock_until(time_point)

Anthony Williams
C++11 Concurrency Tutorial

Just Software Solutions Ltd http://www.justsoftwaresolutions.co.uk
RAII lock templates

Locking and unlocking manually is error-prone,
especially in the face of exceptions.
C++11 provides RAII lock templates to make it
easier to get things right.
std::lock_guard does a simple lock and
unlock
std::unique_lock allows full control

Anthony Williams
C++11 Concurrency Tutorial

Just Software Solutions Ltd http://www.justsoftwaresolutions.co.uk
std::mutex m;
void f(){
m.lock();
std::cout<<"In f()"<<std::endl;
m.unlock();
}
int main(){
m.lock();
std::thread t(f);
for(unsigned i=0;i<5;++i){
std::cout<<"In main()"<<std::endl;
std::this_thread::sleep_for(
std::chrono::seconds(1));
}
m.unlock();
t.join();
}
std::mutex m;
void f(){
std::lock_guard<std::mutex> guard(m);
std::cout<<"In f()"<<std::endl;
}
int main(){
m.lock();
std::thread t(f);
for(unsigned i=0;i<5;++i){
std::cout<<"In main()"<<std::endl;
std::this_thread::sleep_for(
std::chrono::seconds(1));
}
m.unlock();
t.join();
}
std::mutex m;
void f(int i){
std::unique_lock<std::mutex> guard(m);
std::cout<<"In f("<<i<<")"<<std::endl;
guard.unlock();
std::this_thread::sleep_for(
std::chrono::seconds(1));
guard.lock();
std::cout<<"In f("<<i<<") again"<<std::endl;
}
int main(){
std::unique_lock<std::mutex> guard(m);
std::thread t(f,1); std::thread t2(f,2);
std::cout<<"In main()"<<std::endl;
std::this_thread::sleep_for(
std::chrono::seconds(1));
guard.unlock();
t2.join(); t.join();
}
Locking multiple mutexes

class account
{
std::mutex m;
currency_value balance;
public:
friend void transfer(account& from,account& to,
currency_value amount)
{
std::lock_guard<std::mutex> lock_from(from.m
std::lock_guard<std::mutex> lock_to(to.m);
from.balance -= amount;
to.balance += amount;
}
};
Anthony Williams
C++11 Concurrency Tutorial

Just Software Solutions Ltd http://www.justsoftwaresolutions.co.uk
Locking multiple mutexes (II)
void transfer(account& from,account& to,
currency_value amount)
{
std::lock(from.m,to.m);
std::lock_guard<std::mutex> lock_from(
from.m,std::adopt_lock);
std::lock_guard<std::mutex> lock_to(
to.m,std::adopt_lock);
from.balance -= amount;
to.balance += amount;
}

Anthony Williams
C++11 Concurrency Tutorial

Just Software Solutions Ltd http://www.justsoftwaresolutions.co.uk
Waiting for events without futures

Repeatedly poll in a loop (busy-wait)
Wait using a condition variable

Anthony Williams
C++11 Concurrency Tutorial

Just Software Solutions Ltd http://www.justsoftwaresolutions.co.uk
Waiting for an item
If all we’ve got is try_pop(), the only way to wait is to poll:
std::queue<my_class> the_queue;
std::mutex the_mutex;
void wait_and_pop(my_class& data) {
for(;;){
std::lock_guard<std::mutex> guard(the_mutex);
if(!the_queue.empty()) {
data=the_queue.front();
the_queue.pop();
return;
}
}
}
This is not ideal.
Anthony Williams
C++11 Concurrency Tutorial

Just Software Solutions Ltd http://www.justsoftwaresolutions.co.uk
Performing a blocking wait
We want to wait for a particular condition to be true (there is an
item in the queue).
This is a job for std::condition_variable:
std::condition_variable the_cv;
void wait_and_pop(my_class& data) {
std::unique_lock<std::mutex> lk(the_mutex);
the_cv.wait(lk,
[]()
{return !the_queue.empty();});
data=the_queue.front();
the_queue.pop();
}
Anthony Williams
C++11 Concurrency Tutorial

Just Software Solutions Ltd http://www.justsoftwaresolutions.co.uk
Signalling a waiting thread
To signal a waiting thread, we need to notify the condition
variable when we push an item on the queue:
void push(Data const& data)
{
{
std::lock_guard<std::mutex> lk(the_mutex);
the_queue.push(data);
}
the_cv.notify_one();
}

Anthony Williams
C++11 Concurrency Tutorial

Just Software Solutions Ltd http://www.justsoftwaresolutions.co.uk
One-time Initialization
One-time initialization with std::call_once

std::unique_ptr<some_resource> resource_ptr;
std::once_flag resource_flag;
void foo()
{
std::call_once(resource_flag,[]{
resource_ptr.reset(new some_resource);
});
resource_ptr->do_something();
}

Anthony Williams
C++11 Concurrency Tutorial

Just Software Solutions Ltd http://www.justsoftwaresolutions.co.uk
One-time initialization with local statics

void foo()
{
static some_resource resource;
resource.do_something();
}

Anthony Williams
C++11 Concurrency Tutorial

Just Software Solutions Ltd http://www.justsoftwaresolutions.co.uk
Atomics
Atomic types

Sometimes mutexes and locks are too high level
This is where std::atomic<T> comes in
Lock-free for built-in types on popular platforms
Can use std::atomic<POD> — still lock-free for small
structs

Anthony Williams
C++11 Concurrency Tutorial

Just Software Solutions Ltd http://www.justsoftwaresolutions.co.uk
Just::Thread

just::thread provides a complete implementation of the
C++11 thread library for MSVC and g++ on Windows, and g++
for Linux and MacOSX.

Anthony Williams
C++11 Concurrency Tutorial

Just Software Solutions Ltd http://www.justsoftwaresolutions.co.uk
My Book

C++ Concurrency in Action:
Practical Multithreading with
the new C++ Standard.
http:
//stdthread.com/book

Anthony Williams
C++11 Concurrency Tutorial

Just Software Solutions Ltd http://www.justsoftwaresolutions.co.uk

Contenu connexe

Tendances

Embedded Rust on IoT devices
Embedded Rust on IoT devicesEmbedded Rust on IoT devices
Embedded Rust on IoT devicesLars Gregori
 
Linux Char Device Driver
Linux Char Device DriverLinux Char Device Driver
Linux Char Device DriverGary Yeh
 
Hands on Session on Python
Hands on Session on PythonHands on Session on Python
Hands on Session on PythonSumit Raj
 
Rust: Systems Programming for Everyone
Rust: Systems Programming for EveryoneRust: Systems Programming for Everyone
Rust: Systems Programming for EveryoneC4Media
 
Hot С++: Universal References And Perfect Forwarding
Hot С++: Universal References And Perfect ForwardingHot С++: Universal References And Perfect Forwarding
Hot С++: Universal References And Perfect ForwardingAndrey Upadyshev
 
Type casting in java
Type casting in javaType casting in java
Type casting in javaFarooq Baloch
 
Shell and its types in LINUX
Shell and its types in LINUXShell and its types in LINUX
Shell and its types in LINUXSHUBHA CHATURVEDI
 
Rust: Unlocking Systems Programming
Rust: Unlocking Systems ProgrammingRust: Unlocking Systems Programming
Rust: Unlocking Systems ProgrammingC4Media
 
Injection on Steroids: Codeless code injection and 0-day techniques
Injection on Steroids: Codeless code injection and 0-day techniquesInjection on Steroids: Codeless code injection and 0-day techniques
Injection on Steroids: Codeless code injection and 0-day techniquesenSilo
 
Programming Embedded linux
Programming Embedded linuxProgramming Embedded linux
Programming Embedded linuxLiran Ben Haim
 
Read-only rootfs: theory and practice
Read-only rootfs: theory and practiceRead-only rootfs: theory and practice
Read-only rootfs: theory and practiceChris Simmonds
 

Tendances (20)

STL in C++
STL in C++STL in C++
STL in C++
 
Embedded Rust on IoT devices
Embedded Rust on IoT devicesEmbedded Rust on IoT devices
Embedded Rust on IoT devices
 
U-Boot - An universal bootloader
U-Boot - An universal bootloader U-Boot - An universal bootloader
U-Boot - An universal bootloader
 
Hands-on ethernet driver
Hands-on ethernet driverHands-on ethernet driver
Hands-on ethernet driver
 
Shell programming
Shell programmingShell programming
Shell programming
 
Linux Char Device Driver
Linux Char Device DriverLinux Char Device Driver
Linux Char Device Driver
 
Hands on Session on Python
Hands on Session on PythonHands on Session on Python
Hands on Session on Python
 
Rust: Systems Programming for Everyone
Rust: Systems Programming for EveryoneRust: Systems Programming for Everyone
Rust: Systems Programming for Everyone
 
C++ oop
C++ oopC++ oop
C++ oop
 
Hot С++: Universal References And Perfect Forwarding
Hot С++: Universal References And Perfect ForwardingHot С++: Universal References And Perfect Forwarding
Hot С++: Universal References And Perfect Forwarding
 
Toolchain
ToolchainToolchain
Toolchain
 
Type casting in java
Type casting in javaType casting in java
Type casting in java
 
Shell and its types in LINUX
Shell and its types in LINUXShell and its types in LINUX
Shell and its types in LINUX
 
JAVA OOP
JAVA OOPJAVA OOP
JAVA OOP
 
Rust: Unlocking Systems Programming
Rust: Unlocking Systems ProgrammingRust: Unlocking Systems Programming
Rust: Unlocking Systems Programming
 
Injection on Steroids: Codeless code injection and 0-day techniques
Injection on Steroids: Codeless code injection and 0-day techniquesInjection on Steroids: Codeless code injection and 0-day techniques
Injection on Steroids: Codeless code injection and 0-day techniques
 
Programming Embedded linux
Programming Embedded linuxProgramming Embedded linux
Programming Embedded linux
 
Read-only rootfs: theory and practice
Read-only rootfs: theory and practiceRead-only rootfs: theory and practice
Read-only rootfs: theory and practice
 
Plan 9: Not (Only) A Better UNIX
Plan 9: Not (Only) A Better UNIXPlan 9: Not (Only) A Better UNIX
Plan 9: Not (Only) A Better UNIX
 
Java Streams
Java StreamsJava Streams
Java Streams
 

En vedette

認識 C++11 新標準及使用 AMP 函式庫作平行運算
認識 C++11 新標準及使用 AMP 函式庫作平行運算認識 C++11 新標準及使用 AMP 函式庫作平行運算
認識 C++11 新標準及使用 AMP 函式庫作平行運算建興 王
 
Web I - 05 - HTTP Protocol
Web I - 05 - HTTP ProtocolWeb I - 05 - HTTP Protocol
Web I - 05 - HTTP ProtocolRandy Connolly
 
C++17 introduction - Meetup @EtixLabs
C++17 introduction - Meetup @EtixLabsC++17 introduction - Meetup @EtixLabs
C++17 introduction - Meetup @EtixLabsStephane Gleizes
 
"Http protocol and other stuff" by Bipin Upadhyay
"Http protocol and other stuff" by Bipin Upadhyay"Http protocol and other stuff" by Bipin Upadhyay
"Http protocol and other stuff" by Bipin UpadhyayBipin Upadhyay
 
HTTP Protocol Basic
HTTP Protocol BasicHTTP Protocol Basic
HTTP Protocol BasicChuong Mai
 
C++17 - the upcoming revolution (Code::Dive 2015)/
C++17 - the upcoming revolution (Code::Dive 2015)/C++17 - the upcoming revolution (Code::Dive 2015)/
C++17 - the upcoming revolution (Code::Dive 2015)/Sławomir Zborowski
 
Networking - TCP/IP stack introduction and IPv6
Networking - TCP/IP stack introduction and IPv6Networking - TCP/IP stack introduction and IPv6
Networking - TCP/IP stack introduction and IPv6Rodolfo Kohn
 
Elements of C++11
Elements of C++11Elements of C++11
Elements of C++11Uilian Ries
 
Database connectivity to sql server asp.net
Database connectivity to sql server asp.netDatabase connectivity to sql server asp.net
Database connectivity to sql server asp.netHemant Sankhla
 
C++11 Idioms @ Silicon Valley Code Camp 2012
C++11 Idioms @ Silicon Valley Code Camp 2012 C++11 Idioms @ Silicon Valley Code Camp 2012
C++11 Idioms @ Silicon Valley Code Camp 2012 Sumant Tambe
 
C++ 11 Style : A Touch of Class
C++ 11 Style : A Touch of ClassC++ 11 Style : A Touch of Class
C++ 11 Style : A Touch of ClassYogendra Rampuria
 
C# Tutorial MSM_Murach chapter-17-slides
C# Tutorial MSM_Murach chapter-17-slidesC# Tutorial MSM_Murach chapter-17-slides
C# Tutorial MSM_Murach chapter-17-slidesSami Mut
 
C++11 smart pointers
C++11 smart pointersC++11 smart pointers
C++11 smart pointerschchwy Chang
 
Cpp17 and Beyond
Cpp17 and BeyondCpp17 and Beyond
Cpp17 and BeyondComicSansMS
 

En vedette (20)

認識 C++11 新標準及使用 AMP 函式庫作平行運算
認識 C++11 新標準及使用 AMP 函式庫作平行運算認識 C++11 新標準及使用 AMP 函式庫作平行運算
認識 C++11 新標準及使用 AMP 函式庫作平行運算
 
TCP/IP
TCP/IPTCP/IP
TCP/IP
 
Web I - 05 - HTTP Protocol
Web I - 05 - HTTP ProtocolWeb I - 05 - HTTP Protocol
Web I - 05 - HTTP Protocol
 
C++17 introduction - Meetup @EtixLabs
C++17 introduction - Meetup @EtixLabsC++17 introduction - Meetup @EtixLabs
C++17 introduction - Meetup @EtixLabs
 
Bjarne essencegn13
Bjarne essencegn13Bjarne essencegn13
Bjarne essencegn13
 
C++11
C++11C++11
C++11
 
C++11
C++11C++11
C++11
 
C++11 & C++14
C++11 & C++14C++11 & C++14
C++11 & C++14
 
"Http protocol and other stuff" by Bipin Upadhyay
"Http protocol and other stuff" by Bipin Upadhyay"Http protocol and other stuff" by Bipin Upadhyay
"Http protocol and other stuff" by Bipin Upadhyay
 
HTTP Protocol Basic
HTTP Protocol BasicHTTP Protocol Basic
HTTP Protocol Basic
 
C++17 - the upcoming revolution (Code::Dive 2015)/
C++17 - the upcoming revolution (Code::Dive 2015)/C++17 - the upcoming revolution (Code::Dive 2015)/
C++17 - the upcoming revolution (Code::Dive 2015)/
 
Networking - TCP/IP stack introduction and IPv6
Networking - TCP/IP stack introduction and IPv6Networking - TCP/IP stack introduction and IPv6
Networking - TCP/IP stack introduction and IPv6
 
Elements of C++11
Elements of C++11Elements of C++11
Elements of C++11
 
Database connectivity to sql server asp.net
Database connectivity to sql server asp.netDatabase connectivity to sql server asp.net
Database connectivity to sql server asp.net
 
C++11 Idioms @ Silicon Valley Code Camp 2012
C++11 Idioms @ Silicon Valley Code Camp 2012 C++11 Idioms @ Silicon Valley Code Camp 2012
C++11 Idioms @ Silicon Valley Code Camp 2012
 
C++14 Overview
C++14 OverviewC++14 Overview
C++14 Overview
 
C++ 11 Style : A Touch of Class
C++ 11 Style : A Touch of ClassC++ 11 Style : A Touch of Class
C++ 11 Style : A Touch of Class
 
C# Tutorial MSM_Murach chapter-17-slides
C# Tutorial MSM_Murach chapter-17-slidesC# Tutorial MSM_Murach chapter-17-slides
C# Tutorial MSM_Murach chapter-17-slides
 
C++11 smart pointers
C++11 smart pointersC++11 smart pointers
C++11 smart pointers
 
Cpp17 and Beyond
Cpp17 and BeyondCpp17 and Beyond
Cpp17 and Beyond
 

Similaire à C++11 concurrency

High performance web programming with C++14
High performance web programming with C++14High performance web programming with C++14
High performance web programming with C++14Matthieu Garrigues
 
Effective C++/WinRT for UWP and Win32
Effective C++/WinRT for UWP and Win32Effective C++/WinRT for UWP and Win32
Effective C++/WinRT for UWP and Win32Windows Developer
 
Giorgio zoppi cpp11concurrency
Giorgio zoppi cpp11concurrencyGiorgio zoppi cpp11concurrency
Giorgio zoppi cpp11concurrencyGiorgio Zoppi
 
Unit 1 of c++ first program
Unit 1 of c++ first programUnit 1 of c++ first program
Unit 1 of c++ first programAKR Education
 
Assignment c++12
Assignment c++12Assignment c++12
Assignment c++12Syed Umair
 
C++17 not your father’s c++
C++17  not your father’s c++C++17  not your father’s c++
C++17 not your father’s c++Patrick Viafore
 
Effective Modern C++ - Item 35 & 36
Effective Modern C++ - Item 35 & 36Effective Modern C++ - Item 35 & 36
Effective Modern C++ - Item 35 & 36Chih-Hsuan Kuo
 
How to Adopt Modern C++17 into Your C++ Code
How to Adopt Modern C++17 into Your C++ CodeHow to Adopt Modern C++17 into Your C++ Code
How to Adopt Modern C++17 into Your C++ CodeMicrosoft Tech Community
 
How to Adopt Modern C++17 into Your C++ Code
How to Adopt Modern C++17 into Your C++ CodeHow to Adopt Modern C++17 into Your C++ Code
How to Adopt Modern C++17 into Your C++ CodeMicrosoft Tech Community
 
Practical basics on c++
Practical basics on c++Practical basics on c++
Practical basics on c++Marco Izzotti
 
C++ Certified Associate Programmer CPA
C++ Certified Associate Programmer CPAC++ Certified Associate Programmer CPA
C++ Certified Associate Programmer CPAIsabella789
 
JVM Mechanics: When Does the JVM JIT & Deoptimize?
JVM Mechanics: When Does the JVM JIT & Deoptimize?JVM Mechanics: When Does the JVM JIT & Deoptimize?
JVM Mechanics: When Does the JVM JIT & Deoptimize?Doug Hawkins
 
C multiple choice questions and answers pdf
C multiple choice questions and answers pdfC multiple choice questions and answers pdf
C multiple choice questions and answers pdfchoconyeuquy
 
OOPS using C++
OOPS using C++OOPS using C++
OOPS using C++cpjcollege
 
Non Blocking I/O for Everyone with RxJava
Non Blocking I/O for Everyone with RxJavaNon Blocking I/O for Everyone with RxJava
Non Blocking I/O for Everyone with RxJavaFrank Lyaruu
 

Similaire à C++11 concurrency (20)

High performance web programming with C++14
High performance web programming with C++14High performance web programming with C++14
High performance web programming with C++14
 
CPP Quiz
CPP QuizCPP Quiz
CPP Quiz
 
Effective C++/WinRT for UWP and Win32
Effective C++/WinRT for UWP and Win32Effective C++/WinRT for UWP and Win32
Effective C++/WinRT for UWP and Win32
 
Giorgio zoppi cpp11concurrency
Giorgio zoppi cpp11concurrencyGiorgio zoppi cpp11concurrency
Giorgio zoppi cpp11concurrency
 
Unit 1 of c++ first program
Unit 1 of c++ first programUnit 1 of c++ first program
Unit 1 of c++ first program
 
Assignment c++12
Assignment c++12Assignment c++12
Assignment c++12
 
C++17 not your father’s c++
C++17  not your father’s c++C++17  not your father’s c++
C++17 not your father’s c++
 
Effective Modern C++ - Item 35 & 36
Effective Modern C++ - Item 35 & 36Effective Modern C++ - Item 35 & 36
Effective Modern C++ - Item 35 & 36
 
Hems
HemsHems
Hems
 
How to Adopt Modern C++17 into Your C++ Code
How to Adopt Modern C++17 into Your C++ CodeHow to Adopt Modern C++17 into Your C++ Code
How to Adopt Modern C++17 into Your C++ Code
 
How to Adopt Modern C++17 into Your C++ Code
How to Adopt Modern C++17 into Your C++ CodeHow to Adopt Modern C++17 into Your C++ Code
How to Adopt Modern C++17 into Your C++ Code
 
Practical basics on c++
Practical basics on c++Practical basics on c++
Practical basics on c++
 
C++ Basics
C++ BasicsC++ Basics
C++ Basics
 
C++ Certified Associate Programmer CPA
C++ Certified Associate Programmer CPAC++ Certified Associate Programmer CPA
C++ Certified Associate Programmer CPA
 
Fp201 unit2 1
Fp201 unit2 1Fp201 unit2 1
Fp201 unit2 1
 
JVM Mechanics: When Does the JVM JIT & Deoptimize?
JVM Mechanics: When Does the JVM JIT & Deoptimize?JVM Mechanics: When Does the JVM JIT & Deoptimize?
JVM Mechanics: When Does the JVM JIT & Deoptimize?
 
C multiple choice questions and answers pdf
C multiple choice questions and answers pdfC multiple choice questions and answers pdf
C multiple choice questions and answers pdf
 
OOPS using C++
OOPS using C++OOPS using C++
OOPS using C++
 
C++ practical
C++ practicalC++ practical
C++ practical
 
Non Blocking I/O for Everyone with RxJava
Non Blocking I/O for Everyone with RxJavaNon Blocking I/O for Everyone with RxJava
Non Blocking I/O for Everyone with RxJava
 

Dernier

Apidays New York 2024 - The value of a flexible API Management solution for O...
Apidays New York 2024 - The value of a flexible API Management solution for O...Apidays New York 2024 - The value of a flexible API Management solution for O...
Apidays New York 2024 - The value of a flexible API Management solution for O...apidays
 
Apidays New York 2024 - Scaling API-first by Ian Reasor and Radu Cotescu, Adobe
Apidays New York 2024 - Scaling API-first by Ian Reasor and Radu Cotescu, AdobeApidays New York 2024 - Scaling API-first by Ian Reasor and Radu Cotescu, Adobe
Apidays New York 2024 - Scaling API-first by Ian Reasor and Radu Cotescu, Adobeapidays
 
A Year of the Servo Reboot: Where Are We Now?
A Year of the Servo Reboot: Where Are We Now?A Year of the Servo Reboot: Where Are We Now?
A Year of the Servo Reboot: Where Are We Now?Igalia
 
Workshop - Best of Both Worlds_ Combine KG and Vector search for enhanced R...
Workshop - Best of Both Worlds_ Combine  KG and Vector search for  enhanced R...Workshop - Best of Both Worlds_ Combine  KG and Vector search for  enhanced R...
Workshop - Best of Both Worlds_ Combine KG and Vector search for enhanced R...Neo4j
 
Polkadot JAM Slides - Token2049 - By Dr. Gavin Wood
Polkadot JAM Slides - Token2049 - By Dr. Gavin WoodPolkadot JAM Slides - Token2049 - By Dr. Gavin Wood
Polkadot JAM Slides - Token2049 - By Dr. Gavin WoodJuan lago vázquez
 
Top 5 Benefits OF Using Muvi Live Paywall For Live Streams
Top 5 Benefits OF Using Muvi Live Paywall For Live StreamsTop 5 Benefits OF Using Muvi Live Paywall For Live Streams
Top 5 Benefits OF Using Muvi Live Paywall For Live StreamsRoshan Dwivedi
 
Boost PC performance: How more available memory can improve productivity
Boost PC performance: How more available memory can improve productivityBoost PC performance: How more available memory can improve productivity
Boost PC performance: How more available memory can improve productivityPrincipled Technologies
 
From Event to Action: Accelerate Your Decision Making with Real-Time Automation
From Event to Action: Accelerate Your Decision Making with Real-Time AutomationFrom Event to Action: Accelerate Your Decision Making with Real-Time Automation
From Event to Action: Accelerate Your Decision Making with Real-Time AutomationSafe Software
 
Strategies for Landing an Oracle DBA Job as a Fresher
Strategies for Landing an Oracle DBA Job as a FresherStrategies for Landing an Oracle DBA Job as a Fresher
Strategies for Landing an Oracle DBA Job as a FresherRemote DBA Services
 
Strategies for Unlocking Knowledge Management in Microsoft 365 in the Copilot...
Strategies for Unlocking Knowledge Management in Microsoft 365 in the Copilot...Strategies for Unlocking Knowledge Management in Microsoft 365 in the Copilot...
Strategies for Unlocking Knowledge Management in Microsoft 365 in the Copilot...Drew Madelung
 
Apidays Singapore 2024 - Building Digital Trust in a Digital Economy by Veron...
Apidays Singapore 2024 - Building Digital Trust in a Digital Economy by Veron...Apidays Singapore 2024 - Building Digital Trust in a Digital Economy by Veron...
Apidays Singapore 2024 - Building Digital Trust in a Digital Economy by Veron...apidays
 
MINDCTI Revenue Release Quarter One 2024
MINDCTI Revenue Release Quarter One 2024MINDCTI Revenue Release Quarter One 2024
MINDCTI Revenue Release Quarter One 2024MIND CTI
 
Bajaj Allianz Life Insurance Company - Insurer Innovation Award 2024
Bajaj Allianz Life Insurance Company - Insurer Innovation Award 2024Bajaj Allianz Life Insurance Company - Insurer Innovation Award 2024
Bajaj Allianz Life Insurance Company - Insurer Innovation Award 2024The Digital Insurer
 
Understanding Discord NSFW Servers A Guide for Responsible Users.pdf
Understanding Discord NSFW Servers A Guide for Responsible Users.pdfUnderstanding Discord NSFW Servers A Guide for Responsible Users.pdf
Understanding Discord NSFW Servers A Guide for Responsible Users.pdfUK Journal
 
presentation ICT roal in 21st century education
presentation ICT roal in 21st century educationpresentation ICT roal in 21st century education
presentation ICT roal in 21st century educationjfdjdjcjdnsjd
 
Why Teams call analytics are critical to your entire business
Why Teams call analytics are critical to your entire businessWhy Teams call analytics are critical to your entire business
Why Teams call analytics are critical to your entire businesspanagenda
 
TrustArc Webinar - Unlock the Power of AI-Driven Data Discovery
TrustArc Webinar - Unlock the Power of AI-Driven Data DiscoveryTrustArc Webinar - Unlock the Power of AI-Driven Data Discovery
TrustArc Webinar - Unlock the Power of AI-Driven Data DiscoveryTrustArc
 
HTML Injection Attacks: Impact and Mitigation Strategies
HTML Injection Attacks: Impact and Mitigation StrategiesHTML Injection Attacks: Impact and Mitigation Strategies
HTML Injection Attacks: Impact and Mitigation StrategiesBoston Institute of Analytics
 
AWS Community Day CPH - Three problems of Terraform
AWS Community Day CPH - Three problems of TerraformAWS Community Day CPH - Three problems of Terraform
AWS Community Day CPH - Three problems of TerraformAndrey Devyatkin
 
Top 10 Most Downloaded Games on Play Store in 2024
Top 10 Most Downloaded Games on Play Store in 2024Top 10 Most Downloaded Games on Play Store in 2024
Top 10 Most Downloaded Games on Play Store in 2024SynarionITSolutions
 

Dernier (20)

Apidays New York 2024 - The value of a flexible API Management solution for O...
Apidays New York 2024 - The value of a flexible API Management solution for O...Apidays New York 2024 - The value of a flexible API Management solution for O...
Apidays New York 2024 - The value of a flexible API Management solution for O...
 
Apidays New York 2024 - Scaling API-first by Ian Reasor and Radu Cotescu, Adobe
Apidays New York 2024 - Scaling API-first by Ian Reasor and Radu Cotescu, AdobeApidays New York 2024 - Scaling API-first by Ian Reasor and Radu Cotescu, Adobe
Apidays New York 2024 - Scaling API-first by Ian Reasor and Radu Cotescu, Adobe
 
A Year of the Servo Reboot: Where Are We Now?
A Year of the Servo Reboot: Where Are We Now?A Year of the Servo Reboot: Where Are We Now?
A Year of the Servo Reboot: Where Are We Now?
 
Workshop - Best of Both Worlds_ Combine KG and Vector search for enhanced R...
Workshop - Best of Both Worlds_ Combine  KG and Vector search for  enhanced R...Workshop - Best of Both Worlds_ Combine  KG and Vector search for  enhanced R...
Workshop - Best of Both Worlds_ Combine KG and Vector search for enhanced R...
 
Polkadot JAM Slides - Token2049 - By Dr. Gavin Wood
Polkadot JAM Slides - Token2049 - By Dr. Gavin WoodPolkadot JAM Slides - Token2049 - By Dr. Gavin Wood
Polkadot JAM Slides - Token2049 - By Dr. Gavin Wood
 
Top 5 Benefits OF Using Muvi Live Paywall For Live Streams
Top 5 Benefits OF Using Muvi Live Paywall For Live StreamsTop 5 Benefits OF Using Muvi Live Paywall For Live Streams
Top 5 Benefits OF Using Muvi Live Paywall For Live Streams
 
Boost PC performance: How more available memory can improve productivity
Boost PC performance: How more available memory can improve productivityBoost PC performance: How more available memory can improve productivity
Boost PC performance: How more available memory can improve productivity
 
From Event to Action: Accelerate Your Decision Making with Real-Time Automation
From Event to Action: Accelerate Your Decision Making with Real-Time AutomationFrom Event to Action: Accelerate Your Decision Making with Real-Time Automation
From Event to Action: Accelerate Your Decision Making with Real-Time Automation
 
Strategies for Landing an Oracle DBA Job as a Fresher
Strategies for Landing an Oracle DBA Job as a FresherStrategies for Landing an Oracle DBA Job as a Fresher
Strategies for Landing an Oracle DBA Job as a Fresher
 
Strategies for Unlocking Knowledge Management in Microsoft 365 in the Copilot...
Strategies for Unlocking Knowledge Management in Microsoft 365 in the Copilot...Strategies for Unlocking Knowledge Management in Microsoft 365 in the Copilot...
Strategies for Unlocking Knowledge Management in Microsoft 365 in the Copilot...
 
Apidays Singapore 2024 - Building Digital Trust in a Digital Economy by Veron...
Apidays Singapore 2024 - Building Digital Trust in a Digital Economy by Veron...Apidays Singapore 2024 - Building Digital Trust in a Digital Economy by Veron...
Apidays Singapore 2024 - Building Digital Trust in a Digital Economy by Veron...
 
MINDCTI Revenue Release Quarter One 2024
MINDCTI Revenue Release Quarter One 2024MINDCTI Revenue Release Quarter One 2024
MINDCTI Revenue Release Quarter One 2024
 
Bajaj Allianz Life Insurance Company - Insurer Innovation Award 2024
Bajaj Allianz Life Insurance Company - Insurer Innovation Award 2024Bajaj Allianz Life Insurance Company - Insurer Innovation Award 2024
Bajaj Allianz Life Insurance Company - Insurer Innovation Award 2024
 
Understanding Discord NSFW Servers A Guide for Responsible Users.pdf
Understanding Discord NSFW Servers A Guide for Responsible Users.pdfUnderstanding Discord NSFW Servers A Guide for Responsible Users.pdf
Understanding Discord NSFW Servers A Guide for Responsible Users.pdf
 
presentation ICT roal in 21st century education
presentation ICT roal in 21st century educationpresentation ICT roal in 21st century education
presentation ICT roal in 21st century education
 
Why Teams call analytics are critical to your entire business
Why Teams call analytics are critical to your entire businessWhy Teams call analytics are critical to your entire business
Why Teams call analytics are critical to your entire business
 
TrustArc Webinar - Unlock the Power of AI-Driven Data Discovery
TrustArc Webinar - Unlock the Power of AI-Driven Data DiscoveryTrustArc Webinar - Unlock the Power of AI-Driven Data Discovery
TrustArc Webinar - Unlock the Power of AI-Driven Data Discovery
 
HTML Injection Attacks: Impact and Mitigation Strategies
HTML Injection Attacks: Impact and Mitigation StrategiesHTML Injection Attacks: Impact and Mitigation Strategies
HTML Injection Attacks: Impact and Mitigation Strategies
 
AWS Community Day CPH - Three problems of Terraform
AWS Community Day CPH - Three problems of TerraformAWS Community Day CPH - Three problems of Terraform
AWS Community Day CPH - Three problems of Terraform
 
Top 10 Most Downloaded Games on Play Store in 2024
Top 10 Most Downloaded Games on Play Store in 2024Top 10 Most Downloaded Games on Play Store in 2024
Top 10 Most Downloaded Games on Play Store in 2024
 

C++11 concurrency

  • 1. C++11 Concurrency Tutorial Anthony Williams Just Software Solutions Ltd http://www.justsoftwaresolutions.co.uk 28th April 2012
  • 2. C++11 Concurrency Tutorial Asynchronous tasks and threads Promises and tasks Mutexes and condition variables Atomics Anthony Williams C++11 Concurrency Tutorial Just Software Solutions Ltd http://www.justsoftwaresolutions.co.uk
  • 4. Spawning asynchronous tasks Two ways: std::async and std::thread It’s all about things that are Callable: Functions and Member functions Objects with operator() and Lambda functions Anthony Williams C++11 Concurrency Tutorial Just Software Solutions Ltd http://www.justsoftwaresolutions.co.uk
  • 5. Hello World with std::async #include <future> // for std::async #include <iostream> void write_message(std::string const& message) { std::cout<<message; } int main() { auto f=std::async(write_message, "hello world from std::asyncn"); write_message("hello world from mainn"); f.wait(); } Anthony Williams C++11 Concurrency Tutorial Just Software Solutions Ltd http://www.justsoftwaresolutions.co.uk
  • 6. Hello World with std::thread #include <thread> // for std::thread #include <iostream> void write_message(std::string const& message) { std::cout<<message; } int main() { std::thread t(write_message, "hello world from std::threadn"); write_message("hello world from mainn"); t.join(); } Anthony Williams C++11 Concurrency Tutorial Just Software Solutions Ltd http://www.justsoftwaresolutions.co.uk
  • 7. Missing join with std::thread #include <thread> #include <iostream> void write_message(std::string const& message) { std::cout<<message; } int main() { std::thread t(write_message, "hello world from std::threadn"); write_message("hello world from mainn"); // oops no join } Anthony Williams C++11 Concurrency Tutorial Just Software Solutions Ltd http://www.justsoftwaresolutions.co.uk
  • 8. Missing wait with std::async #include <future> #include <iostream> void write_message(std::string const& message) { std::cout<<message; } int main() { auto f=std::async(write_message, "hello world from std::asyncn"); write_message("hello world from mainn"); // oops no wait } Anthony Williams C++11 Concurrency Tutorial Just Software Solutions Ltd http://www.justsoftwaresolutions.co.uk
  • 9. Async Launch Policies The standard launch policies are the members of the std::launch scoped enum. They can be used individually or together. Anthony Williams C++11 Concurrency Tutorial Just Software Solutions Ltd http://www.justsoftwaresolutions.co.uk
  • 10. Async Launch Policies std::launch::async => “as if” in a new thread. std::launch::deferred => executed on demand. std::launch::async | std::launch::deferred => implementation chooses (default). Anthony Williams C++11 Concurrency Tutorial Just Software Solutions Ltd http://www.justsoftwaresolutions.co.uk
  • 11. std::launch::async #include <future> #include <iostream> #include <stdio.h> void write_message(std::string const& message) { std::cout<<message; } int main() { auto f=std::async( std::launch::async,write_message, "hello world from std::asyncn"); write_message("hello world from mainn"); getchar(); f.wait(); } Anthony Williams C++11 Concurrency Tutorial Just Software Solutions Ltd http://www.justsoftwaresolutions.co.uk
  • 12. std::launch::deferred #include <future> #include <iostream> #include <stdio.h> void write_message(std::string const& message) { std::cout<<message; } int main() { auto f=std::async( std::launch::deferred,write_message, "hello world from std::asyncn"); write_message("hello world from mainn"); getchar(); f.wait(); } Anthony Williams C++11 Concurrency Tutorial Just Software Solutions Ltd http://www.justsoftwaresolutions.co.uk
  • 13. Returning values with std::async #include <future> #include <iostream> int find_the_answer() { return 42; } int main() { auto f=std::async(find_the_answer); std::cout<<"the answer is "<<f.get()<<"n"; } Anthony Williams C++11 Concurrency Tutorial Just Software Solutions Ltd http://www.justsoftwaresolutions.co.uk
  • 14. Passing parameters #include <future> #include <iostream> std::string copy_string(std::string const&s) { return s; } int main() { std::string s="hello"; auto f=std::async(std::launch::deferred, copy_string,s); s="goodbye"; std::cout<<f.get()<<" world!n"; } Anthony Williams C++11 Concurrency Tutorial Just Software Solutions Ltd http://www.justsoftwaresolutions.co.uk
  • 15. Passing parameters with std::ref #include <future> #include <iostream> std::string copy_string(std::string const&s) { return s; } int main() { std::string s="hello"; auto f=std::async(std::launch::deferred, copy_string,std::ref(s)); s="goodbye"; std::cout<<f.get()<<" world!n"; } Anthony Williams C++11 Concurrency Tutorial Just Software Solutions Ltd http://www.justsoftwaresolutions.co.uk
  • 16. Passing parameters with a lambda std::string copy_string(std::string const&s) { return s; } int main() { std::string s="hello"; auto f=std::async(std::launch::deferred, [&s](){return copy_string(s);}); s="goodbye"; std::cout<<f.get()<<" world!n"; } Anthony Williams C++11 Concurrency Tutorial Just Software Solutions Ltd http://www.justsoftwaresolutions.co.uk
  • 17. std::async passes exceptions #include <future> #include <iostream> int find_the_answer() { throw std::runtime_error("Unable to find the answe } int main() { auto f=std::async(find_the_answer); try { std::cout<<"the answer is "<<f.get()<<"n"; } catch(std::runtime_error const& e) { std::cout<<"nCaught exception: "<<e.what()<<std } } Anthony Williams C++11 Concurrency Tutorial Just Software Solutions Ltd http://www.justsoftwaresolutions.co.uk
  • 19. Manually setting futures Two ways: std::promise and std::packaged_task std::promise allows you to explicitly set the value std::packaged_task is for manual task invocation, e.g. thread pools. Anthony Williams C++11 Concurrency Tutorial Just Software Solutions Ltd http://www.justsoftwaresolutions.co.uk
  • 20. std::promise #include <future> #include <thread> #include <iostream> void find_the_answer(std::promise<int>* p) { p->set_value(42); } int main() { std::promise<int> p; auto f=p.get_future(); std::thread t(find_the_answer,&p); std::cout<<"the answer is "<<f.get()<<"n"; t.join(); } Anthony Williams C++11 Concurrency Tutorial Just Software Solutions Ltd http://www.justsoftwaresolutions.co.uk
  • 21. std::packaged_task #include <future> #include <thread> #include <iostream> int find_the_answer() { return 42; } int main() { std::packaged_task<int()> task(find_the_answer); auto f=task.get_future(); std::thread t(std::move(task)); std::cout<<"the answer is "<<f.get()<<"n"; t.join(); } Anthony Williams C++11 Concurrency Tutorial Just Software Solutions Ltd http://www.justsoftwaresolutions.co.uk
  • 22. Waiting for futures from multiple threads Use std::shared_future<T> rather than std::future<T> std::future<int> f=/*...*/; std::shared_future<int> sf(std::move(f)); std::future<int> f2=/*...*/; std::shared_future<int> sf2(f.share()); std::promise<int> p; std::shared_future<int> sf3(p.get_future()); Anthony Williams C++11 Concurrency Tutorial Just Software Solutions Ltd http://www.justsoftwaresolutions.co.uk
  • 23. #include <future> #include <thread> #include <iostream> #include <sstream> void wait_for_notify(int id,std::shared_future<int> sf) std::ostringstream os; os<<"Thread "<<id<<" waitingn"; std::cout<<os.str(); os.str(""); os<<"Thread "<<id<<" woken, val="<<sf.get()<<"n"; std::cout<<os.str(); } int main() { std::promise<int> p; auto sf=p.get_future().share(); std::thread t1(wait_for_notify,1,sf); std::thread t2(wait_for_notify,2,sf); std::cout<<"Waitingn"; std::cin.get(); p.set_value(42); t2.join(); t1.join(); }
  • 24. std::shared_future<T> objects cannot be shared Anthony Williams C++11 Concurrency Tutorial Just Software Solutions Ltd http://www.justsoftwaresolutions.co.uk
  • 25. Separate std::shared_future<T> objects can share state Anthony Williams C++11 Concurrency Tutorial Just Software Solutions Ltd http://www.justsoftwaresolutions.co.uk
  • 27. Lower level synchronization Locks and Mutexes Condition variables Anthony Williams C++11 Concurrency Tutorial Just Software Solutions Ltd http://www.justsoftwaresolutions.co.uk
  • 28. Mutexes C++11 has 4 mutex classes: std::mutex std::recursive_mutex std::timed_mutex std::recursive_timed_mutex Anthony Williams C++11 Concurrency Tutorial Just Software Solutions Ltd http://www.justsoftwaresolutions.co.uk
  • 29. Mutex operations (I) Mutexes have 3 basic operations, which form the Lockable concept: m.lock() m.try_lock() m.unlock() Anthony Williams C++11 Concurrency Tutorial Just Software Solutions Ltd http://www.justsoftwaresolutions.co.uk
  • 30. Mutex operations (II) “Timed” mutexes have 2 additional operations. A Lockable type that provides them satisfies the TimedLockable concept. m.try_lock_for(duration) m.try_lock_until(time_point) Anthony Williams C++11 Concurrency Tutorial Just Software Solutions Ltd http://www.justsoftwaresolutions.co.uk
  • 31. RAII lock templates Locking and unlocking manually is error-prone, especially in the face of exceptions. C++11 provides RAII lock templates to make it easier to get things right. std::lock_guard does a simple lock and unlock std::unique_lock allows full control Anthony Williams C++11 Concurrency Tutorial Just Software Solutions Ltd http://www.justsoftwaresolutions.co.uk
  • 32. std::mutex m; void f(){ m.lock(); std::cout<<"In f()"<<std::endl; m.unlock(); } int main(){ m.lock(); std::thread t(f); for(unsigned i=0;i<5;++i){ std::cout<<"In main()"<<std::endl; std::this_thread::sleep_for( std::chrono::seconds(1)); } m.unlock(); t.join(); }
  • 33. std::mutex m; void f(){ std::lock_guard<std::mutex> guard(m); std::cout<<"In f()"<<std::endl; } int main(){ m.lock(); std::thread t(f); for(unsigned i=0;i<5;++i){ std::cout<<"In main()"<<std::endl; std::this_thread::sleep_for( std::chrono::seconds(1)); } m.unlock(); t.join(); }
  • 34. std::mutex m; void f(int i){ std::unique_lock<std::mutex> guard(m); std::cout<<"In f("<<i<<")"<<std::endl; guard.unlock(); std::this_thread::sleep_for( std::chrono::seconds(1)); guard.lock(); std::cout<<"In f("<<i<<") again"<<std::endl; } int main(){ std::unique_lock<std::mutex> guard(m); std::thread t(f,1); std::thread t2(f,2); std::cout<<"In main()"<<std::endl; std::this_thread::sleep_for( std::chrono::seconds(1)); guard.unlock(); t2.join(); t.join(); }
  • 35. Locking multiple mutexes class account { std::mutex m; currency_value balance; public: friend void transfer(account& from,account& to, currency_value amount) { std::lock_guard<std::mutex> lock_from(from.m std::lock_guard<std::mutex> lock_to(to.m); from.balance -= amount; to.balance += amount; } }; Anthony Williams C++11 Concurrency Tutorial Just Software Solutions Ltd http://www.justsoftwaresolutions.co.uk
  • 36. Locking multiple mutexes (II) void transfer(account& from,account& to, currency_value amount) { std::lock(from.m,to.m); std::lock_guard<std::mutex> lock_from( from.m,std::adopt_lock); std::lock_guard<std::mutex> lock_to( to.m,std::adopt_lock); from.balance -= amount; to.balance += amount; } Anthony Williams C++11 Concurrency Tutorial Just Software Solutions Ltd http://www.justsoftwaresolutions.co.uk
  • 37. Waiting for events without futures Repeatedly poll in a loop (busy-wait) Wait using a condition variable Anthony Williams C++11 Concurrency Tutorial Just Software Solutions Ltd http://www.justsoftwaresolutions.co.uk
  • 38. Waiting for an item If all we’ve got is try_pop(), the only way to wait is to poll: std::queue<my_class> the_queue; std::mutex the_mutex; void wait_and_pop(my_class& data) { for(;;){ std::lock_guard<std::mutex> guard(the_mutex); if(!the_queue.empty()) { data=the_queue.front(); the_queue.pop(); return; } } } This is not ideal. Anthony Williams C++11 Concurrency Tutorial Just Software Solutions Ltd http://www.justsoftwaresolutions.co.uk
  • 39. Performing a blocking wait We want to wait for a particular condition to be true (there is an item in the queue). This is a job for std::condition_variable: std::condition_variable the_cv; void wait_and_pop(my_class& data) { std::unique_lock<std::mutex> lk(the_mutex); the_cv.wait(lk, []() {return !the_queue.empty();}); data=the_queue.front(); the_queue.pop(); } Anthony Williams C++11 Concurrency Tutorial Just Software Solutions Ltd http://www.justsoftwaresolutions.co.uk
  • 40. Signalling a waiting thread To signal a waiting thread, we need to notify the condition variable when we push an item on the queue: void push(Data const& data) { { std::lock_guard<std::mutex> lk(the_mutex); the_queue.push(data); } the_cv.notify_one(); } Anthony Williams C++11 Concurrency Tutorial Just Software Solutions Ltd http://www.justsoftwaresolutions.co.uk
  • 42. One-time initialization with std::call_once std::unique_ptr<some_resource> resource_ptr; std::once_flag resource_flag; void foo() { std::call_once(resource_flag,[]{ resource_ptr.reset(new some_resource); }); resource_ptr->do_something(); } Anthony Williams C++11 Concurrency Tutorial Just Software Solutions Ltd http://www.justsoftwaresolutions.co.uk
  • 43. One-time initialization with local statics void foo() { static some_resource resource; resource.do_something(); } Anthony Williams C++11 Concurrency Tutorial Just Software Solutions Ltd http://www.justsoftwaresolutions.co.uk
  • 45. Atomic types Sometimes mutexes and locks are too high level This is where std::atomic<T> comes in Lock-free for built-in types on popular platforms Can use std::atomic<POD> — still lock-free for small structs Anthony Williams C++11 Concurrency Tutorial Just Software Solutions Ltd http://www.justsoftwaresolutions.co.uk
  • 46. Just::Thread just::thread provides a complete implementation of the C++11 thread library for MSVC and g++ on Windows, and g++ for Linux and MacOSX. Anthony Williams C++11 Concurrency Tutorial Just Software Solutions Ltd http://www.justsoftwaresolutions.co.uk
  • 47. My Book C++ Concurrency in Action: Practical Multithreading with the new C++ Standard. http: //stdthread.com/book Anthony Williams C++11 Concurrency Tutorial Just Software Solutions Ltd http://www.justsoftwaresolutions.co.uk