Kurs i

Threads Programming using Modern C++

Buggar i fler-trådade program anses ofta vara det besvärligaste man kan råka ut för som programmerare. Faktum är att det generella rådet är att inte stoppa in dem från början.

Om man tycker det rådet är aningen orealistiskt, så är det näst bästa att programmera enligt ett antal väl beprövade programmerings-idiom som undviker problemen. I denna kurs, fokuserar vi på just den strategin.

Denna kurs överlappar delvis med vår andra kurs "POSIX & C11 Threads Programming using C", men skiljer sig åt genom att dessutom kapsla in alla C data-typer i bättre C++ klasser, samt givetvis en ordentlig genomgång av threads i C++11.

Detta får du lära dig på kursen
  • Programmera med POSIX Threads direkt i C
  • Programmera med trådar i C++, genom att kapsla in C API:et
  • Programmera med trådar i nya C++14
  • Förstå och hantera problemområden som critical-sections, race-conditions och deadlocks
  • Använda mutex och conditions både i POSIX och C++11
  • Förstå och använda futures & promises i nya C++11
  • Förstå hur du på bästa sätt använder mutex och condition variabler i såväl C, C++ som nya C++11
  • Förstå hur du använder futures och promises för att implementera client-server trådar
Innehåll

Introduction to Threads and Concurrency

  • Concurrent vs. parallel
  • Scheduling
  • Synchronization
  • Virtual adress space organization
  • Overview of how a function-call is performed and why it's relevant to threads

POSIX Threads

  • Overview of the POSIX Threads C API
  • Creating a thread
  • Passing paramaters to a new thread
  • Configuring threads, like setting the stack-size
  • Implementing class Thread

The Critical Section Problem

  • Understanding the problem and its solution
  • Three conditions for the critical-section problem
  • POSIX mutex variables
  • Configuration
  • Handling timeouts
  • Avoiding self-deadlock
  • Implementing class Mutex
  • Implementing class Guard

The Race-Condition Problem

  • Understanding the problem and its solution
  • POSIX condition variables
  • Configuration
  • Handling timeouts
  • Understanding monitor semantics
  • The minimum amount of code to safely transfer data from one thread to another
  • Implementing class Condition
  • Implementing class MailBox

The Deadlock Problem

  • The concept resource
  • Understanding the problem and its solution
  • Four conditions for the deadlock problem
  • Preventing deadlocks
  • Detection of deadlocks

Synchronization and Other Data-Types

  • Read/Write locks
  • Barriers
  • Thread-local storage
  • Implementing classes for read/write locks
  • Implementing class Barrier
  • Implementing class ThreadLocalStorage

Semaphores

  • POSIX semaphores
  • Memory-based vs. file-based semaphores
  • Implementing class Semaphore
  • Implementing class FileSemaphore

Uni-directional Message Passing

  • What is message-passing
  • Handling pointer based messages
  • Understanding the message-queue concept and its synchronization requirements
  • Implementing class MessageQueue
  • Implementing class MessageThread
  • Implementing interface Receivable
  • Implementing a threads pipeline

Bi-directional Message Passing

  • N clients & 1 server
  • 1 client & N servers
  • Understanding Extended Rendezvous
  • Implementation of Extended Rendezvous
  • Understanding Futures
  • Implementation of Futures

Shared Memory

  • What is shared memory
  • Understanding the mmap() system call
  • The POSIX Shared Memory API
  • Implementing class SharedMemory

Threads & Processes

  • Creating processes
  • Waiting for process termination
  • Adapting mutexes and conditions for shared memory
  • Implementation of a message-queue in shared memory
  • Implementation of a threads pipeline between processes and via shared memory

A quick C++11/14 Primer

  • Highlights of the new standard relevant for the following chapters

Threads in C++11

  • Overview of the threads support in C++11/14
  • Using class thread
  • Usage of lambda expressions when defining threads

C++11 Synchronization

  • Using class mutex
  • Using class condition_variable
  • Usage of lock guards
  • Usage of multi-locking and avoidance of deadlocks
  • Implementation of class MessageQueue<T> using C++11

C++ Futures

  • Understanding C++11 promises & futures
  • Implementing Extended Rendezvous using C++11 futures
  • Spawning asynchronous tasks
SnabbFakta
Namn
Threads Programming using Modern C++
Längd
3 dagar
Nivå
Advanced
Målgrupp
Erfarna C++ programmerare
Förkunskaper
Vana att programmera i modern C++ 11/14, dock ej POSIX eller C++11 Threads
Teknisk miljö
  • C++14 compliant C++ compiler
  • A decent IDE such as Jetbrains CLion
  • Ubuntu Linux or Cygwin
Relaterade Kurser
Schemalagd Kurs

Pris

18000 kr + moms

Vi ger 20% rabatt för tillkommande deltagare från samma företag på samma kurstillfälle. Läs mer om vår samma-företags-rabatt.

Aktuella KursDatum
Startdatum Plats
10 maj 2017 Stockholm City
13 jun 2017 Stockholm City
Företagsintern Kurs

Om du beställer en företagsintern kurs kommer vi till er och håller kursen i era egna lokaler. Priset bestäms av vår prismodell och baseras på antalet kursdagar, antalet deltagare, samt i förekommande fall resa och logi.

Prisexempel för NN deltagare

PPP kr + moms

Antal
Område

Läs mer om vår prismodell och beställningsvillkor.