Introduction à la programmation concurrente

Documents pareils
4. Outils pour la synchronisation F. Boyer, Laboratoire Lig

Problèmes liés à la concurrence

Exercices INF5171 : série #3 (Automne 2012)

Introduction aux systèmes temps réel. Iulian Ober IRIT

03/04/2007. Tâche 1 Tâche 2 Tâche 3. Système Unix. Time sharing

J2SE Threads, 1ère partie Principe Cycle de vie Création Synchronisation

Exclusion Mutuelle. Arnaud Labourel Courriel : arnaud.labourel@lif.univ-mrs.fr. Université de Provence. 9 février 2011

4. Outils pour la synchronisation F. Boyer, Laboratoire Sardes

On appelle variable condition une var qui peut être testée et

Introduction : les processus. Introduction : les threads. Plan

Synchro et Threads Java TM

Les processus légers : threads. Système L3, /31

Info0604 Programmation multi-threadée. Cours 5. Programmation multi-threadée en Java

INTRODUCTION À LA PROGRAMMATION CONCURRENTE

INTRODUCTION AUX SYSTEMES D EXPLOITATION. TD2 Exclusion mutuelle / Sémaphores

Cours 2: Exclusion Mutuelle entre processus (lourds, ou légers -- threads)

Threads. Threads. USTL routier 1

Bases de programmation. Cours 5. Structurer les données

LOG4430 : Architecture et conception avancée

Sixième partie. Programmation multi-activités Java & Posix Threads. Généralités Java Threads POSIX Threads Autres approches

Introduction à Java. Matthieu Herrb CNRS-LAAS. Mars

Cours de Systèmes d Exploitation

Un ordonnanceur stupide

Programmer en JAVA. par Tama

Projet gestion d'objets dupliqués

Exécutif temps réel Pierre-Yves Duval (cppm)

Éléments d informatique Cours 3 La programmation structurée en langage C L instruction de contrôle if

NIVEAU D'INTERVENTION DE LA PROGRAMMATION CONCURRENTE

Centre CPGE TSI - Safi 2010/2011. Algorithmique et programmation :

Notion de thread (1/2)

Processus! programme. DIMA, Systèmes Centralisés (Ph. Mauran) " Processus = suite d'actions = suite d'états obtenus = trace

École Polytechnique de Montréal. Département de Génie Informatique et Génie Logiciel. Cours INF2610. Contrôle périodique.

INITIATION AU LANGAGE JAVA

M2-Images. Rendu Temps Réel - OpenGL 4 et compute shaders. J.C. Iehl. December 18, 2013

1. Structure d un programme C. 2. Commentaire: /*..texte */ On utilise aussi le commentaire du C++ qui est valable pour C: 3.

Exceptions. 1 Entrées/sorties. Objectif. Manipuler les exceptions ;

1 Mesure de la performance d un système temps réel : la gigue

Prénom : Matricule : Sigle et titre du cours Groupe Trimestre INF1101 Algorithmes et structures de données Tous H2004. Loc Jeudi 29/4/2004

Premiers Pas en Programmation Objet : les Classes et les Objets

as Architecture des Systèmes d Information

Génie Logiciel avec Ada. 4 février 2013

Introduction à la Programmation Parallèle: MPI

Noyau de concurrence par moniteur pour Java ou C# pour une autre sémantique plus fiable et plus performante

Une introduction à Java

Rappel. Analyse de Données Structurées - Cours 12. Un langage avec des déclaration locales. Exemple d'un programme

Java Licence Professionnelle CISII,

Table des matières PRESENTATION DU LANGAGE DS2 ET DE SES APPLICATIONS. Introduction

Cahier des charges. driver WIFI pour chipset Ralink RT2571W. sur hardware ARM7

Programmation d Applications Concurrentes et Distribuées (INF431)

IN Cours 1. 1 Informatique, calculateurs. 2 Un premier programme en C

Structurer ses données : les tableaux. Introduction à la programmation

Programmation Orientée Objet Java

Les structures de données. Rajae El Ouazzani

Programmation Orientée Objet - Licence TIS CM8/9. Rappel sur la séance précédente. Lancelot Pecquet Lancelot.Pecquet@math.univ-poitiers.

Ordonnancement temps réel

TD2 Programmation concurrentielle

Licence Bio Informatique Année Premiers pas. Exercice 1 Hello World parce qu il faut bien commencer par quelque chose...

Introduction aux Systèmes et aux Réseaux

Développement Logiciel

Gestion des transactions et accès concurrents dans les bases de données relationnelles

Java Licence Professionnelle CISII, Cours 2 : Classes et Objets

Auto-évaluation Programmation en Java

Performances de la programmation multi-thread

Langage et Concepts de ProgrammationOrientée-Objet 1 / 40

Traduction des Langages : Le Compilateur Micro Java

Systèmes temps-réel. Plan général. Matthieu Herrb. Mars Introduction - concepts généraux

Temps Réel. Jérôme Pouiller Septembre 2011

REALISATION d'un. ORDONNANCEUR à ECHEANCES

Applet pour visualiser les variables «automate» notifiées

Arbres binaires de recherche

JADE : Java Agent DEvelopment framework. Laboratoire IBISC & Départ. GEII Université & IUT d Evry nadia.abchiche@ibisc.univ-evry.

Apprendre la Programmation Orientée Objet avec le langage Java (avec exercices pratiques et corrigés)

Recherche dans un tableau

ARDUINO DOSSIER RESSOURCE POUR LA CLASSE

Conventions d écriture et outils de mise au point

Cours 1: Java et les objets

TD2/TME2 : Ordonnanceur et Threads (POSIX et fair)

IFT Systèmes d exploitation - TP n 1-20%

Suivant les langages de programmation, modules plus avancés : modules imbriqués modules paramétrés par des modules (foncteurs)

RAPPELS SUR LES METHODES HERITEES DE LA CLASSE RACINE Object ET LEUR SPECIALISATION (i.e. REDEFINITION)

La technologie Java Card TM

Programmation MacOSX / ios

Polymorphisme, la classe Object, les package et la visibilité en Java... 1

Plateforme PAYZEN. Définition de Web-services

Cours 1 : La compilation

Cours intensif Java. 1er cours: de C à Java. Enrica DUCHI LIAFA, Paris 7. Septembre Enrica.Duchi@liafa.jussieu.fr

Les transactions 1/46. I même en cas de panne logicielle ou matérielle. I Concept de transaction. I Gestion de la concurrence : les solutions

Cours 6 : Tubes anonymes et nommés

Utilisation d objets : String et ArrayList

EPREUVE OPTIONNELLE d INFORMATIQUE CORRIGE

PIGOURIER Vincent ANNEE SPECIALE 99/00 RAPPORT DE PROJET : LES THREADS JAVA. Responsable : Serge Rouveyrol

Programme Compte bancaire (code)

Notes de cours : bases de données distribuées et repliquées

Paginer les données côté serveur, mettre en cache côté client

TD3: tableaux avancées, première classe et chaînes

Programmation avec des objets : Cours 7. Menu du jour

Systèmes d exploitation Gestion de processus

OS Réseaux et Programmation Système - C5

Transcription:

Introduction à la programmation concurrente Moniteurs Yann Thoma Reconfigurable and Embedded Digital Systems Institute Haute Ecole d Ingénierie et de Gestion du Canton de Vaud This work is licensed under a Creative Commons Attribution-NonCommercial-ShareAlike 3.0 Unported License Mars 2015 Y. Thoma (HES-SO / HEIG-VD / REDS) Introduction à la programmation concurrente Mars 2015 1 / 34 Introduction Introduction Concept de moniteur Proposé par Hoare en 1974 Permet de résoudre la synchronisation des tâches Permet de regrouper des variables ainsi que les procédures agissant sur ces variables Assure l exclusion mutuelle sur les procédures du moniteur Synchronisation assurée par des primitives wait() signal() Y. Thoma (HES-SO / HEIG-VD / REDS) Introduction à la programmation concurrente Mars 2015 2 / 34

Introduction Introduction Les procédures du moniteur s exécutent en exclusion mutuelle La synchronisation se fait via des variables de condition L idée est que l exécution d une partie de code dépend d une condition Y-a-t-il une donnée à exploiter? Est-ce que le thread Y a terminé son traitement?... Une variable de condition va permettre de faire attendre le thread jusqu à ce qu une condition C soit remplie Un autre thread pourra réveiller un ou plusieurs threads lorsqu il aura garanti cette condition C Y. Thoma (HES-SO / HEIG-VD / REDS) Introduction à la programmation concurrente Mars 2015 3 / 34 Introduction Structure d un moniteur monitor <nom> <déclarations des variables rémanentes locales>; <déclarations des variables conditions>; procedure OpérationLocale(liste de paramètres) <déclarations des variables locales>; begin <code pour implémenter l opération>; end; entry procedure OpérationVisible(liste de paramètres) <déclarations des variables locales>; begin <code pour implémenter l opération>; end; begin <code pour initialiser les variables rémanentes>; end; Y. Thoma (HES-SO / HEIG-VD / REDS) Introduction à la programmation concurrente Mars 2015 4 / 34

Variable condition Introduction Synchronisation des tâches grâce aux variables conditions (VC) Une VC offre 2 primitives: attente signale Soit la VC cond déclarée par condition cond; cond.attente bloque inconditionnellement la tâche appelante lui fait relâcher l exclusion mutuelle sur le moniteur la place dans une file associée à cond cond.signale dépend de l état de la file associée à cond vide la tâche appelante poursuit son exécution et l opération n a aucun effet. pas vide une des tâches bloquées est réactivée et reprend immédiatement son exécution Y. Thoma (HES-SO / HEIG-VD / REDS) Introduction à la programmation concurrente Mars 2015 5 / 34 Introduction Exemple: Verrou par moniteur monitor VerrouMoniteur var verrou: boolean; var acces: condition; entry procedure Verrouille begin if verrou then acces.attente; verrou := true; end Verrouille; entry procedure Deverrouille begin verrou := false; acces.signale; end Deverrouille; begin verrou := false; end VerrouMoniteur; Y. Thoma (HES-SO / HEIG-VD / REDS) Introduction à la programmation concurrente Mars 2015 6 / 34

Introduction Exemple: Producteur-consommateur monitor Tampons var place: array [0..N-1] of ARTICLE; var tete, queue, taille: integer; var pasplein, pasvide: condition; entry procedure deposer(a: ARTICLE) begin if taille = N then pasplein.attente; taille := taille + 1; place[tete] := a; tete := (tete + 1) mod N; pasvide.signale; end deposer; entry procedure retirer(var a: ARTICLE) begin if taille = 0 then pasvide.attente; a := place[queue]; taille := taille - 1; queue := (queue + 1) mod N; pasplein.signale; end retirer; begin taille := 0; queue := 0; tete := 0; end Tampons; Y. Thoma (HES-SO / HEIG-VD / REDS) Introduction à la programmation concurrente Mars 2015 7 / 34 Un moniteur en Qt associe: Un mutex, qui assure l exclusion mutuelle Une variable de condition, qui sert de point de signalisation Classe QWaitCondition Y. Thoma (HES-SO / HEIG-VD / REDS) Introduction à la programmation concurrente Mars 2015 8 / 34

Fonctions : Attente bool QWaitCondition::wait(QMutex * lockedmutex, unsigned long time = ULONG_MAX) Effectue les opérations suivantes de manière atomique: Relâche le mutex lockedmutex Attend que la variable de condition soit signalée. L exécution du thread est suspendue (attente passive) jusqu à ce que la variable condition soit signalée. Le mutex doit être verrouillé par le thread avant l appel à wait. Au moment où la condition est signalée, wait re-verrouille automatiquement le mutex. Attention, lors du re-verrouillage le thread est en compétition avec tous les threads demandant le verrou!!! Le paramètre time permet de borner l attente en temps. Nous ne l utiliserons pas dans ce cours. Y. Thoma (HES-SO / HEIG-VD / REDS) Introduction à la programmation concurrente Mars 2015 9 / 34 Fonctions : Signalisation void QWaitCondition::wakeOne(); réveille un des threads en attente sur la variable condition: si aucun thread n est en attente, la fonction n a aucun effet ; si plusieurs threads sont en attente, un seul est réveillé (choisi par l ordonnanceur). void QWaitCondition::wakeAll(); réveille tous les threads en attente sur cond: si aucun thread n est en attente, la fonction n a aucun effet ; les threads réveillés continuent leur exécution chacun à leur tour, car le mutex ne peut être repris que par un thread à la fois (l ordre est imprévisible et dépend de l ordonnanceur). Y. Thoma (HES-SO / HEIG-VD / REDS) Introduction à la programmation concurrente Mars 2015 10 / 34

Pour la culture: Fonctions Posix Fonction int pthread_cond_init(pthread_cond_t *cond, const pthread_condattr_t *attr) int pthread_cond_wait(pthread_cond_t *cond, pthread_mutex_t *mutex) int pthread_cond_timedwait(pthread_cond_t *cond, pthread_mutex_t *mutex, const struct timespec *abstime) Description Initialisation d une variable condition Attente sur la variable Attente avec échéance pthread_cond_signal(pthread_cond_t *cond) Réveil potentiel d un thread pthread_cond_broadcast(pthread_cond_t *cond) Réveil de tous les threads en attente Y. Thoma (HES-SO / HEIG-VD / REDS) Introduction à la programmation concurrente Mars 2015 11 / 34 Structure type des points d entrée d un moniteur en Qt void MyMonitor::oneFunction() { mutex.acquire(); // Evaluer C while(!c) { variablecond.wait(&mutex); // Réévaluer C si nécessaire // Exécuter la fonction demandée mutex.release(); void MyMonitor::anotherFunction() { mutex.acquire(); // Faire quelque chose // Modifier la condition C (passer à true) variablecond.wakeone(); mutex.release(); Y. Thoma (HES-SO / HEIG-VD / REDS) Introduction à la programmation concurrente Mars 2015 12 / 34

Exemple de producteurs/consommateurs class Buffer { private: QMutex mutex; QWaitCondition estlibre, estplein; char *tampon; public: Buffer() { tampon = 0; Y. Thoma (HES-SO / HEIG-VD / REDS) Introduction à la programmation concurrente Mars 2015 13 / 34 Exemple de producteurs/consommateurs en POSIX /* Depose le message msg (qui est dupliqué) et bloque tant que le ** tampon est plein. */ void put(char *msg) { mutex.acquire(); while (tampon!= NULL) estlibre.wait(&mutex); if ((tampon = (char *)malloc(strlen(msg) + 1))!= NULL) { strcpy(tampon,msg); estplein.wakeone(); mutex.release(); /* Renvoie le message du tampon et bloque tant que le tampon est vide. ** La libération de la mémoire contenant le message est à la charge de ** l appelant. */ char *get(void) { char *resultat; mutex.acquire(); while (buffer == NULL) estplein.wait(&mutex); resultat = tampon; tampon = NULL; mutex.release(); estlibre.wakeone(); return resultat; Y. Thoma (HES-SO / HEIG-VD / REDS) Introduction à la programmation concurrente Mars 2015 14 / 34

Implémentation de moniteurs à partir de sémaphores Si les variables de condition ne sont pas offertes Possibilité de créer un moniteur à base de sémaphores Y. Thoma (HES-SO / HEIG-VD / REDS) Introduction à la programmation concurrente Mars 2015 15 / 34 Implémentation de moniteurs à partir de sémaphores (1) Etape 1: Une classe étant exploitée comme un moniteur a besoin des éléments suivants : typedef struct { QSemaphore mutex; QSemaphore signale; // file bloquante des signaleurs unsigned nbsignale; // tâches en attente dans signal T_Moniteur; T_Moniteur mon; Y. Thoma (HES-SO / HEIG-VD / REDS) Introduction à la programmation concurrente Mars 2015 16 / 34

Implémentation de moniteurs à partir de sémaphores (2) Etape 2: Chaque procédure constituant un point d entrée du moniteur est encadrée par : // <code de la procédure> Y. Thoma (HES-SO / HEIG-VD / REDS) Introduction à la programmation concurrente Mars 2015 17 / 34 Implémentation de moniteurs à partir de sémaphores (3) Etape 3: Pour chaque variable condition cond du moniteur, créer un enregistrement: typedef struct { QSemaphore attente; unsigned nbattente; // tâches en attente T_Condition; T_Condition cond; Y. Thoma (HES-SO / HEIG-VD / REDS) Introduction à la programmation concurrente Mars 2015 18 / 34

Implémentation de moniteurs à partir de sémaphores (4) Etape 4: Dans toutes les procédures du moniteur, substituer cond.attente par : cond.nbattente += 1; // Avant de se mettre en attente, libérer un thread ayant émis // un signal // Avant de se mettre en attente, libérer le mutex pour laisser // un autre thread rentrer dans le moniteur cond.attente.acquire(); cond.nbattente -= 1; Y. Thoma (HES-SO / HEIG-VD / REDS) Introduction à la programmation concurrente Mars 2015 19 / 34 Implémentation de moniteurs à partir de sémaphores (5) Etape 5: Dans toutes les procédures du moniteur, substituer cond.signale par : if (cond.nbattente > 0) { mon.nbsignale += 1; cond.attente.release(); mon.signale.acquire(); // Pour laisser la priorité au thread réveillé mon.nbsignale -= 1; Y. Thoma (HES-SO / HEIG-VD / REDS) Introduction à la programmation concurrente Mars 2015 20 / 34

Exemple: producteurs/consommateurs monitor Tampons var place: array [0..N-1] of ARTICLE; var tete, queue, taille: integer; var pasplein, pasvide: condition; begin taille := 0; queue := 0; tete := 0; end Tampons; class ProdConsSem { T_Moniteur mon; ARTICLE place[0..n-1]; int tete, queue, taille; T_Condition pasplein, pasvide; Y. Thoma (HES-SO / HEIG-VD / REDS) Introduction à la programmation concurrente Mars 2015 21 / 34 Exemple: producteurs/consommateurs monitor Tampons entry procedure deposer(a: ARTICLE) begin if taille = N then pasplein.attente; taille := taille + 1; place[tete] := a; tete := (tete + 1) mod N; pasvide.signale; end deposer; end Tampons; void deposer(article a) { if (taille == N) { pasplein.nbattente += 1; pasplein.attente.acquire(); pasplein.nbattente -= 1; taille += 1; place[tete] = a; tete = (tete + 1) % N; if (pasvide.nbattente > 0) { mon.nbsignale += 1; pasvide.attente.release(); mon.signale.acquire(); mon.nbsignale -= 1; Y. Thoma (HES-SO / HEIG-VD / REDS) Introduction à la programmation concurrente Mars 2015 22 / 34

Exemple: producteurs/consommateurs monitor Tampons entry procedure retirer(var a: ARTICLE) begin if taille = 0 then pasvide.attente; a := place[queue]; taille := taille - 1; queue := (queue + 1) mod N; pasplein.signale; end retirer; end Tampons; void retirer(article *a) { if (taille == 0) { pasvide.nbattente += 1; pasvide.attente.acquire(); pasvide.nbattente -= 1; a = place[queue]; taille -= 1; queue = (queue + 1) % N; if (pasplein.nbattente > 0) { mon.nbsignale += 1; pasplein.attente.release(); mon.signale.acquire(); mon.nbsignale -= 1; Y. Thoma (HES-SO / HEIG-VD / REDS) Introduction à la programmation concurrente Mars 2015 23 / 34 Optimisation (1) void deposer(article a) { if (taille == N) { pasplein.nbattente += 1; pasplein.attente.acquire(); pasplein.nbattente -= 1; taille += 1; place[tete] = a; tete = (tete + 1) % N; if (pasvide.nbattente > 0) { mon.nbsignale += 1; pasvide.attente.release(); mon.signale.acquire(); mon.nbsignale -= 1; void deposer(article a) { if (taille == N) { pasplein.nbattente += 1; pasplein.attente.acquire(); pasplein.nbattente -= 1; taille += 1; place[tete] = a; tete = (tete + 1) % N; if (pasvide.nbattente > 0) pasvide.attente.release(); Y. Thoma (HES-SO / HEIG-VD / REDS) Introduction à la programmation concurrente Mars 2015 24 / 34

Optimisation (2) void deposer(article a) { if (taille == N) { pasplein.nbattente += 1; pasplein.attente.acquire(); pasplein.nbattente -= 1; taille += 1; place[tete] = a; tete = (tete + 1) % N; if (pasvide.nbattente > 0) pasvide.attente.release(); void deposer(article a) { if (taille == N) { pasplein.nbattente += 1; pasplein.attente.acquire(); pasplein.nbattente -= 1; taille += 1; place[tete] = a; tete = (tete + 1) % N; if (pasvide.nbattente > 0) pasvide.attente.release(); Y. Thoma (HES-SO / HEIG-VD / REDS) Introduction à la programmation concurrente Mars 2015 25 / 34 Optimisation (3) solution void deposer(article a) { if (taille == N) { pasplein.nbattente += 1; pasplein.attente.acquire(); pasplein.nbattente -= 1; taille += 1; place[tete] = a; tete = (tete + 1) % N; if (pasvide.nbattente > 0) pasvide.attente.release(); void retirer(article *a) { if (taille == 0) { pasvide.nbattente += 1; pasvide.attente.acquire(); pasvide.nbattente -= 1; a = place[queue]; taille -= 1; queue = (queue + 1) % N; if (pasplein.nbattente > 0) pasplein.attente.release(); Y. Thoma (HES-SO / HEIG-VD / REDS) Introduction à la programmation concurrente Mars 2015 26 / 34

Remarques finales Avantages des moniteurs une protection associée au moniteur (exclusion mutuelle); une souplesse d utilisation des primitives attente et signale; une efficacité de ces mécanismes. Inconvénients des moniteurs un risque de manque de lisibilité qui est partiellement dû à des variations sémantiques des implémentations dans les divers langages qui les supportent. Dans le cas de pthread ou de Qt, il n y a aucune garantie que les variables partagées sont effectivement accédées uniquement depuis les points d entrée du moniteur qui devrait les protéger; les variables condition sont de bas niveau; l impossibilité d imposer un ordre total ou partiel dans l exécution des procédures ou fonctions exportées. Y. Thoma (HES-SO / HEIG-VD / REDS) Introduction à la programmation concurrente Mars 2015 27 / 34 Moniteurs en C++ Moniteurs en C++ Le concept de moniteur se prête bien à une implémentation OO Définition de la classe class MyMonitor { protected: QMutex mutex; QWaitCondition cond; bool unecondition; public: MyMonitor() {; ~ MyMonitor {; void onefunction(); void anotherfunction(); Y. Thoma (HES-SO / HEIG-VD / REDS) Introduction à la programmation concurrente Mars 2015 28 / 34

Moniteurs en C++ Moniteurs en C++ Méthodes void MyMonitor::oneFunction() { mutex.acquire(); while (!unecondition) cond.wait(&mutex); mutex.release(); void MyMonitor::anotherFunction() { mutex.acquire(); unecondition = true; cond.wakeone(); mutex.release(); Y. Thoma (HES-SO / HEIG-VD / REDS) Introduction à la programmation concurrente Mars 2015 29 / 34 Moniteurs en Java Moniteurs en Java Le mécanisme de synchronisation natif à Java est le moniteur Dans une classe, les méthodes peuvent être déclarées synchronized Le mot-clé synchronized garanti l exclusion mutuelle sur ces méthodes Identique à l idée d avoir un mutex dans la classe, verrouillé en début de méthode et relâché en fin Exemple class UniqueID { private int id; public synchronized int getid() { return id ++; public synchronized void decrid() { id --; Y. Thoma (HES-SO / HEIG-VD / REDS) Introduction à la programmation concurrente Mars 2015 30 / 34

Moniteurs en Java Moniteurs en Java La synchronisation est ensuite développée à l aide de 3 méthodes: wait() : Suspend la tâche appelante jusqu au réveil de l objet courant notify() : Réveille une tâche bloquée sur un wait() notifyall() : Réveille toutes les tâches bloquées sur un wait() Attention, l ordre de réveil n est pas défini, il peut être quelconque Et une tâche réveillée doit réacquérir l exclusion mutuelle Y. Thoma (HES-SO / HEIG-VD / REDS) Introduction à la programmation concurrente Mars 2015 31 / 34 Moniteurs en Java Moniteurs en Java Exemple: un sémaphore en Java public class Semaphore { private int value; /* la valeur du semaphore */ private int nbwait = 0; /* nb en attente */ public Semaphore(int initval) { value = initval; public synchronized void wait() { while (value <= 0) { nbwait++; wait(); value--; Attente public synchronized void post() { value++; if (nbwait > 0) { nbwait--; notify(); Réveil d une tâche Y. Thoma (HES-SO / HEIG-VD / REDS) Introduction à la programmation concurrente Mars 2015 32 / 34

Moniteurs en Java Moniteurs en Java Exemple: un sémaphore en Java (plus simple) public class Semaphore { private int value; /* la valeur du semaphore */ public Semaphore(int initval) { value = initval; public synchronized void wait() { while (value <= 0) { wait(); value--; Attente public synchronized void post() { value++; notify(); Réveil d une tâche Y. Thoma (HES-SO / HEIG-VD / REDS) Introduction à la programmation concurrente Mars 2015 33 / 34 Moniteurs en Java Moniteurs en Java Il est également possible de ne synchroniser une partie d une méthode Pour avoir des files d attente de type FIFO il faut effectuer leur gestion de manière explicite Dans Java 7 il y a: Des Lock qui offrent le même type de fonctionnement que les verrous Des Condition qui offrent des variables de conditions Il y a dès lors plus de flexibilité à disposition Y. Thoma (HES-SO / HEIG-VD / REDS) Introduction à la programmation concurrente Mars 2015 34 / 34