Introduction à la programmation concurrente
|
|
|
- Raphaël Carbonneau
- il y a 10 ans
- Total affichages :
Transcription
1 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 / 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 / 34
2 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 / 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 / 34
3 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 / 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 / 34
4 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 / 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 / 34
5 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 / 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 / 34
6 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 / 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 / 34
7 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 / 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 / 34
8 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 / 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 / 34
9 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 / 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 / 34
10 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 / 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 / 34
11 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 / 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 / 34
12 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 / 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 / 34
13 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 / 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 / 34
14 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 / 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 / 34
15 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 / 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 / 34
16 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 / 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 / 34
17 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 / 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 / 34
4. Outils pour la synchronisation F. Boyer, Laboratoire Lig [email protected]
4. Outils pour la synchronisation F. Boyer, Laboratoire Lig [email protected] Le problème Insuffisance des solutions de base (verrous) Les solutions de plus haut niveau Les Sémaphores Les Moniteurs
Problèmes liés à la concurrence
ENS Cachan Problématique Difficile de gérer la concurrence : Pas toujours facile d avoir des fonctions réentrantes. Risque de race condition : ex : x :=x+1 x :=x+1 On voudrait des blocs d instructions
Exercices INF5171 : série #3 (Automne 2012)
Exercices INF5171 : série #3 (Automne 2012) 1. Un moniteur pour gérer des ressources Le moniteur MPD 1 présente une première version d'un moniteur, exprimé en pseudo-mpd, pour gérer des ressources le nombre
Introduction aux systèmes temps réel. Iulian Ober IRIT [email protected]
Introduction aux systèmes temps réel Iulian Ober IRIT [email protected] Sommaire Généralités Caractéristiques récurrentes des STR Types de problèmes soulevées Programmation des STR Prog. concurrente
03/04/2007. Tâche 1 Tâche 2 Tâche 3. Système Unix. Time sharing
3/4/27 Programmation Avancée Multimédia Multithreading Benoît Piranda Équipe SISAR Université de Marne La Vallée Besoin Programmes à traitements simultanés Réseau Réseau Afficher une animation en temps
J2SE Threads, 1ère partie Principe Cycle de vie Création Synchronisation
J2SE Threads, 1ère partie Principe Cycle de vie Création Synchronisation Cycle Ingénierie 2e année SIGL Dernière mise à jour : 19/10/2006 Christophe Porteneuve Threads Principes Cycle de vie Création java.lang.thread
Exclusion Mutuelle. Arnaud Labourel Courriel : [email protected]. Université de Provence. 9 février 2011
Arnaud Labourel Courriel : [email protected] Université de Provence 9 février 2011 Arnaud Labourel (Université de Provence) Exclusion Mutuelle 9 février 2011 1 / 53 Contexte Epistémologique
4. Outils pour la synchronisation F. Boyer, Laboratoire Sardes [email protected]
4. Outils pour la synchronisation F. Boyer, Laboratoire Sardes [email protected] Le problème Insuffisance des solutions de base (verrous) Les solutions de plus haut niveau Les Sémaphores Les Moniteurs
On appelle variable condition une var qui peut être testée et
Un concept plus général: g Variables condition On appelle variable condition une var qui peut être testée et endort le thread qui la teste si la condition est fausse le réveille quand la condition devient
Introduction : les processus. Introduction : les threads. Plan
IN328 Programmation distribuée avec Java et J2EE 2 - Threads en Java Introduction : les processus Un processus est un ensemble d instructions à exécuter, un espace mémoire réservé et éventuellement d autres
Synchro et Threads Java TM
Synchro et Threads Java TM NICOD JEAN-MARC Master 2 Informatique Université de Franche-Comté UFR des Sciences et Techniques septembre 2008 NICOD JEAN-MARC Synchro et Threads avec Java TM 1 / 32 Sommaire
Les processus légers : threads. Système L3, 2014-2015 1/31
Les processus légers : threads Système L3, 2014-2015 1/31 Les threads Les threads sont des processus légers exécutés à l intérieur d un processus L exécution des threads est concurrente Il existe toujours
Info0604 Programmation multi-threadée. Cours 5. Programmation multi-threadée en Java
Info0604 Programmation multi-threadée Cours 5 Programmation multi-threadée en Java Pierre Delisle Université de Reims Champagne-Ardenne Département de Mathématiques et Informatique 18 février 2015 Plan
INTRODUCTION À LA PROGRAMMATION CONCURRENTE
INTRODUCTION À LA PROGRAMMATION CONCURRENTE POLYCOPIÉ DU COURS PCO1 Prof. Claude Evéquoz Prof. Yann Thoma HEIG-VD 2009 Table des matières Table des matières 2 1 Introduction à la programmation concurrente
INTRODUCTION AUX SYSTEMES D EXPLOITATION. TD2 Exclusion mutuelle / Sémaphores
INTRODUCTION AUX SYSTEMES D EXPLOITATION TD2 Exclusion mutuelle / Sémaphores Exclusion mutuelle / Sémaphores - 0.1 - S O M M A I R E 1. GENERALITES SUR LES SEMAPHORES... 1 1.1. PRESENTATION... 1 1.2. UN
Cours 2: Exclusion Mutuelle entre processus (lourds, ou légers -- threads)
Cours 2: Exclusion Mutuelle entre processus (lourds, ou légers -- threads) Concurrence entre processus & Problème d Exclusion Mutuelle 1. Introduction 2. Solutions avec attente active, dites Sans Arbitrage
Threads. Threads. USTL http://www.lifl.fr/ routier 1
Threads USTL http://www.lifl.fr/ routier 1 Rappels - Définitions un Process est un programme qui tourne et dispose de ses propres ressources mémoire. OS multi-tâche plusieurs process en concurrence un
Bases de programmation. Cours 5. Structurer les données
Bases de programmation. Cours 5. Structurer les données Pierre Boudes 1 er décembre 2014 This work is licensed under the Creative Commons Attribution-NonCommercial-ShareAlike 3.0 License. Types char et
LOG4430 : Architecture et conception avancée
LOG4430 : Architecture et conception avancée Abdou Maiga Patrons pour la conception d applications distribuées Département de génie informatique et de génie logiciel École Polytechnique de Montréal Guéhéneuc,
Sixième partie. Programmation multi-activités Java & Posix Threads. Généralités Java Threads POSIX Threads Autres approches
Sixième partie Programmation multi-activités Java & Posix Threads Systèmes concurrents 2 / 55 Plan 1 2 Synchronisation (java d'origine) Synchronisation (java moderne) 3 Synchronisation 4 Microsoft Windows
Introduction à Java. Matthieu Herrb CNRS-LAAS. Mars 2014. http://homepages.laas.fr/matthieu/cours/java/java.pdf
Introduction à Java Matthieu Herrb CNRS-LAAS http://homepages.laas.fr/matthieu/cours/java/java.pdf Mars 2014 Plan 1 Concepts 2 Éléments du langage 3 Classes et objets 4 Packages 2/28 Histoire et motivations
Cours de Systèmes d Exploitation
Licence d informatique Synchronisation et Communication inter-processus Hafid Bourzoufi Université de Valenciennes - ISTV Introduction Les processus concurrents s exécutant dans le système d exploitation
Un ordonnanceur stupide
Un ordonnanceur simple Université Paris Sud L objet des exercices qui suivent est de créer un ordonanceur implantant l algorithme du tourniquet ( round-robin scheduler ). La technique utilisée pour élire
Programmer en JAVA. par Tama ([email protected]( [email protected])
Programmer en JAVA par Tama ([email protected]( [email protected]) Plan 1. Présentation de Java 2. Les bases du langage 3. Concepts avancés 4. Documentation 5. Index des mots-clés 6. Les erreurs fréquentes
Projet gestion d'objets dupliqués
Projet gestion d'objets dupliqués Daniel Hagimont [email protected] 1 Projet Service de gestion d'objets dupliqués Mise en cohérence lors de la prise d'un verrou sur un objet Pas de verrous imbriqués
Exécutif temps réel Pierre-Yves Duval (cppm)
Exécutif temps réel Pierre-Yves Duval (cppm) Ecole d informatique temps réel - La Londes les Maures 7-11 Octobre 2002 Plan Exécutif Tâches Evénements et synchronisation Partage de ressources Communications
Éléments d informatique Cours 3 La programmation structurée en langage C L instruction de contrôle if
Éléments d informatique Cours 3 La programmation structurée en langage C L instruction de contrôle if Pierre Boudes 28 septembre 2011 This work is licensed under the Creative Commons Attribution-NonCommercial-ShareAlike
NIVEAU D'INTERVENTION DE LA PROGRAMMATION CONCURRENTE
NIVEAU D'INTERVENTION DE LA PROGRAMMATION CONCURRENTE Une application se construit par étapes 1) CAHIER DES CHARGES + ANALYSE FONCTIONNELLE = organisation fonctionnelle (QUE FAIRE) 2) ANALYSE OPERATIONNELLE
Centre CPGE TSI - Safi 2010/2011. Algorithmique et programmation :
Algorithmique et programmation : STRUCTURES DE DONNÉES A. Structure et enregistrement 1) Définition et rôle des structures de données en programmation 1.1) Définition : En informatique, une structure de
Notion de thread (1/2)
Notion de thread (1/2) La machine virtuelle java (JVM) permet d'exécuter plusieurs traitements en parallèle (en pratique, ils s'exécutent par tranche et en alternance sur le processeur). Ces traitements
Processus! programme. DIMA, Systèmes Centralisés (Ph. Mauran) " Processus = suite d'actions = suite d'états obtenus = trace
Processus 1) Contexte 2) Modèles de Notion de Points de vue Modèle fourni par le SX Opérations sur les 3) Gestion des Représentation des Opérations 4) Ordonnancement des Niveaux d ordonnancement Ordonnancement
École Polytechnique de Montréal. Département de Génie Informatique et Génie Logiciel. Cours INF2610. Contrôle périodique.
École Polytechnique de Montréal Département de Génie Informatique et Génie Logiciel Cours INF2610 Contrôle périodique Automne 2013 Date : 11 octobre 2013 de 18h à 20h Professeur : Boucheneb Hanifa Documentation
INITIATION AU LANGAGE JAVA
INITIATION AU LANGAGE JAVA I. Présentation 1.1 Historique : Au début des années 90, Sun travaillait sur un projet visant à concevoir des logiciels simples et performants exécutés dans des PDA (Personnal
M2-Images. Rendu Temps Réel - OpenGL 4 et compute shaders. J.C. Iehl. December 18, 2013
Rendu Temps Réel - OpenGL 4 et compute shaders December 18, 2013 résumé des épisodes précédents... création des objets opengl, organisation des données, configuration du pipeline, draw,... opengl 4.3 :
1. Structure d un programme C. 2. Commentaire: /*..texte */ On utilise aussi le commentaire du C++ qui est valable pour C: 3.
1. Structure d un programme C Un programme est un ensemble de fonctions. La fonction "main" constitue le point d entrée pour l exécution. Un exemple simple : #include int main() { printf ( this
Exceptions. 1 Entrées/sorties. Objectif. Manipuler les exceptions ;
CNAM NFP121 TP 10 19/11/2013 (Séance 5) Objectif Manipuler les exceptions ; 1 Entrées/sorties Exercice 1 : Lire un entier à partir du clavier Ajouter une méthode readint(string message) dans la classe
1 Mesure de la performance d un système temps réel : la gigue
TP TR ENSPS et MSTER 1 Travaux Pratiques Systèmes temps réel et embarqués ENSPS ISV et Master TP1 - Ordonnancement et communication inter-processus (IPC) Environnement de travail Un ordinateur dual-core
Prénom : Matricule : Sigle et titre du cours Groupe Trimestre INF1101 Algorithmes et structures de données Tous H2004. Loc Jeudi 29/4/2004
Questionnaire d'examen final INF1101 Sigle du cours Nom : Signature : Prénom : Matricule : Sigle et titre du cours Groupe Trimestre INF1101 Algorithmes et structures de données Tous H2004 Professeur(s)
Premiers Pas en Programmation Objet : les Classes et les Objets
Chapitre 2 Premiers Pas en Programmation Objet : les Classes et les Objets Dans la première partie de ce cours, nous avons appris à manipuler des objets de type simple : entiers, doubles, caractères, booléens.
as Architecture des Systèmes d Information
Plan Plan Programmation - Introduction - Nicolas Malandain March 14, 2005 Introduction à Java 1 Introduction Présentation Caractéristiques Le langage Java 2 Types et Variables Types simples Types complexes
Génie Logiciel avec Ada. 4 février 2013
Génie Logiciel 4 février 2013 Plan I. Généralités II. Structures linéaires III. Exceptions IV. Structures arborescentes V. Dictionnaires I. Principes II. Notions propres à la POO I. Principes Chapitre
Introduction à la Programmation Parallèle: MPI
Introduction à la Programmation Parallèle: MPI Frédéric Gava et Gaétan Hains L.A.C.L Laboratoire d Algorithmique, Complexité et Logique Cours du M2 SSI option PSSR Plan 1 Modèle de programmation 2 3 4
Noyau de concurrence par moniteur pour Java ou C# pour une autre sémantique plus fiable et plus performante
Noyau de concurrence par moniteur pour Java ou C# pour une autre sémantique plus fiable et plus performante Claude Kaiser, Jean-François Pradat-Peyre CEDRIC - CNAM Paris 292, rue St Martin, 75003 Paris
Une introduction à Java
Une introduction à Java IFT 287 (Semaine 1) UNIVERSITÉ DE SHERBROOKE 1 Java - Historique Développé par Sun Microsystems en 1994 Inventeur James Gosling (canadien!) Objectif langage sûr (fortement typé)
Rappel. Analyse de Données Structurées - Cours 12. Un langage avec des déclaration locales. Exemple d'un programme
Rappel Ralf Treinen Université Paris Diderot UFR Informatique Laboratoire Preuves, Programmes et Systèmes [email protected] 6 mai 2015 Jusqu'à maintenant : un petit langage de programmation
Java Licence Professionnelle CISII, 2009-10
Java Licence Professionnelle CISII, 2009-10 Cours 4 : Programmation structurée (c) http://www.loria.fr/~tabbone/cours.html 1 Principe - Les méthodes sont structurées en blocs par les structures de la programmation
Table des matières PRESENTATION DU LANGAGE DS2 ET DE SES APPLICATIONS. Introduction
PRESENTATION DU LANGAGE DS2 ET DE SES APPLICATIONS Depuis SAS 9.2 TS2M3, SAS propose un nouveau langage de programmation permettant de créer et gérer des tables SAS : le DS2 («Data Step 2»). Ces nouveautés
Cahier des charges. driver WIFI pour chipset Ralink RT2571W. sur hardware ARM7
Cahier des charges driver WIFI pour chipset Ralink RT2571W sur hardware ARM7 RevA 13/03/2006 Création du document Sylvain Huet RevB 16/03/2006 Fusion des fonctions ARP et IP. SH Modification des milestones
Programmation d Applications Concurrentes et Distribuées (INF431)
Programmation d Applications Concurrentes et Distribuées (INF431) Julien Cervelle Albert Cohen Eric Goubault Francesco Zappa Nardelli François Pottier Samuel Mimram Benjamin Werner 1er janvier 2015 2 Table
IN 102 - Cours 1. 1 Informatique, calculateurs. 2 Un premier programme en C
IN 102 - Cours 1 Qu on le veuille ou non, les systèmes informatisés sont désormais omniprésents. Même si ne vous destinez pas à l informatique, vous avez de très grandes chances d y être confrontés en
Structurer ses données : les tableaux. Introduction à la programmation
Structurer ses données : les tableaux Introduction à la programmation Plan du document Introduction Introduire la notion de type Types primitifs Types composés Tableaux de type primitif Page 2 Notion de
Programmation Orientée Objet Java
Programmation Orientée Objet Java Bertrand Estellon Département Informatique et Interactions Aix-Marseille Université 12 novembre 2014 Bertrand Estellon (DII AMU) Programmation Orientée Objet Java 12 novembre
Les structures de données. Rajae El Ouazzani
Les structures de données Rajae El Ouazzani Les arbres 2 1- Définition de l arborescence Une arborescence est une collection de nœuds reliés entre eux par des arcs. La collection peut être vide, cad l
Programmation Orientée Objet - Licence TIS CM8/9. Rappel sur la séance précédente. Lancelot Pecquet [email protected].
Programmation Orientée Objet - Licence TIS CM8/9 Lancelot Pecquet [email protected] Poitiers, le 13/03/2006 Rappel sur la séance précédente La fois précédente, nous avons vu : 1 UML
Ordonnancement temps réel
Ordonnancement temps réel [email protected] Version 1.5 Problématique de l ordonnancement temps réel En fonctionnement normal, respecter les contraintes temporelles spécifiées par toutes les tâches
TD2 Programmation concurrentielle
TD2 Programmation concurrentielle Développement Logiciel (L2-S4) Lundi 10 février 2014 Exercice 1 (Au bar...) Trois clients se trouvent au bar. Il est tard, ils sont fatigués, et ils s endorment sur le
Licence Bio Informatique Année 2004-2005. Premiers pas. Exercice 1 Hello World parce qu il faut bien commencer par quelque chose...
Université Paris 7 Programmation Objet Licence Bio Informatique Année 2004-2005 TD n 1 - Correction Premiers pas Exercice 1 Hello World parce qu il faut bien commencer par quelque chose... 1. Enregistrez
Introduction aux Systèmes et aux Réseaux
Introduction aux Systèmes et aux Réseaux Cours 5 Processus D après un cours de Julien Forget (univ Lille1) Laure Gonnord http://laure.gonnord.org/pro/teaching/ [email protected] Master CCI -
Développement Logiciel
Développement Logiciel Éxamen session 1-2012-2013 (Vendedi 25 mai, 9h-11h) Seuls les documents liés directement au cours sont autorisés (comme dit sur le site) : sujets de TD, notes de cours, notes personnelles
Gestion des transactions et accès concurrents dans les bases de données relationnelles
Gestion des transactions et accès concurrents dans les bases de données relationnelles Bernard ESPINASSE Professeur à Aix-Marseille Université (AMU) Ecole Polytechnique Universitaire de Marseille Fev.
Java Licence Professionnelle CISII, 2009-2010. Cours 2 : Classes et Objets
Licence Professionnelle CISII, 2009-2010 Cours 2 : Classes et Objets 1 Classes et Objets Objectifs des LOO : - Manipuler des objets - Découper les programmes suivant les types des objets manipulés - Regrouper
Auto-évaluation Programmation en Java
Auto-évaluation Programmation en Java Document: f0883test.fm 22/01/2013 ABIS Training & Consulting P.O. Box 220 B-3000 Leuven Belgium TRAINING & CONSULTING INTRODUCTION AUTO-ÉVALUATION PROGRAMMATION EN
Performances de la programmation multi-thread
UFR Sciences et techniques de Franche-Comté Projet semestriel 2ème année de Master Informatique Performances de la programmation multi-thread Auteur(s) : Beuque Eric Moutenet Cyril Tuteur(s) : Philippe
Langage et Concepts de ProgrammationOrientée-Objet 1 / 40
Déroulement du cours Introduction Concepts Java Remarques Langage et Concepts de Programmation Orientée-Objet Gauthier Picard École Nationale Supérieure des Mines de Saint-Étienne [email protected]
Traduction des Langages : Le Compilateur Micro Java
BARABZAN Jean-René OUAHAB Karim TUCITO David 2A IMA Traduction des Langages : Le Compilateur Micro Java µ Page 1 Introduction Le but de ce projet est d écrire en JAVA un compilateur Micro-Java générant
Systèmes temps-réel. Plan général. Matthieu Herrb. http://homepages.laas.fr/matthieu/temps-reel.pdf. Mars 2015. 1 Introduction - concepts généraux
Systèmes temps-réel Matthieu Herrb http://homepages.laas.fr/matthieu/temps-reel.pdf Mars 2015 Plan général 1 Introduction - concepts généraux 2 Processus 3 Synchronisation 4 Gestion de la mémoire 5 Conclusion
Temps Réel. Jérôme Pouiller <[email protected]> Septembre 2011
Temps Réel Jérôme Pouiller Septembre 2011 Ordonnancement avec contraintes de précédance Problèmatique des accès concurents Problème liés aux partage de ressources Solutions utres
REALISATION d'un. ORDONNANCEUR à ECHEANCES
REALISATION d'un ORDONNANCEUR à ECHEANCES I- PRÉSENTATION... 3 II. DESCRIPTION DU NOYAU ORIGINEL... 4 II.1- ARCHITECTURE... 4 II.2 - SERVICES... 4 III. IMPLÉMENTATION DE L'ORDONNANCEUR À ÉCHÉANCES... 6
Applet pour visualiser les variables «automate» notifiées
Applet pour visualiser les variables «automate» notifiées Sommaire 1. Introduction...2 2. Lecture de variables «automate» notifiées...2 2.1. IHM servant au test :...2 2.2. Codage de l'applet :...2 3. Codage
Arbres binaires de recherche
1 arbre des comparaisons 2 recherche dichotomique l'arbre est recalculé à chaque recherche 2 5 3 4 7 9 1 6 1 2 3 4 5 6 7 9 10 conserver la structure d'arbre au lieu de la reconstruire arbre binaire de
JADE : Java Agent DEvelopment framework. Laboratoire IBISC & Départ. GEII Université & IUT d Evry [email protected].
: Java Agent DEvelopment framework Laboratoire IBISC & Départ. GEII Université & IUT d Evry [email protected] Introduction à la plateforme JADE 1) Modèle d agent 2) Services 3) Norme FIPA
Apprendre la Programmation Orientée Objet avec le langage Java (avec exercices pratiques et corrigés)
Introduction à la POO 1. Histoire de la POO 9 2. Historique du 12 La conception orientée objet 1. Approche procédurale et décomposition fonctionnelle 13 2. La transition vers l'approche objet 14 3. Les
Recherche dans un tableau
Chapitre 3 Recherche dans un tableau 3.1 Introduction 3.1.1 Tranche On appelle tranche de tableau, la donnée d'un tableau t et de deux indices a et b. On note cette tranche t.(a..b). Exemple 3.1 : 3 6
ARDUINO DOSSIER RESSOURCE POUR LA CLASSE
ARDUINO DOSSIER RESSOURCE POUR LA CLASSE Sommaire 1. Présentation 2. Exemple d apprentissage 3. Lexique de termes anglais 4. Reconnaître les composants 5. Rendre Arduino autonome 6. Les signaux d entrée
Conventions d écriture et outils de mise au point
Logiciel de base Première année par alternance Responsable : Christophe Rippert [email protected] Introduction Conventions d écriture et outils de mise au point On va utiliser dans cette
Cours 1: Java et les objets
Ressources Les interface homme-machine et le langage Java DUT première année Henri Garreta, Faculté des Sciences (Luminy) Cyril Pain-Barre & Sébastien Nedjar, IUT d Aix-Marseille (Aix) Cours 1: infodoc.iut.univ-aix.fr/~ihm/
TD2/TME2 : Ordonnanceur et Threads (POSIX et fair)
UE PC2R page 1/8 TD2/TME2 : Ordonnanceur et Threads (POSIX et fair) Exercice 1 (Modélisation) Chemin de Fer Cet exercice est dédié à l étude d un problème de circulation de trains : Voie! out1 in1 Voie!
IFT2245 - Systèmes d exploitation - TP n 1-20%
IFT2245 - Systèmes d exploitation - TP n 1-20% DIRO - Université de Montréal Nicolas Rous et Dorian Gomez Disponible : 14/02/2013 - Remise : 28/03/2013 au début de la démo LISEZ TOUT LE DOCUMENT AVANT
Suivant les langages de programmation, modules plus avancés : modules imbriqués modules paramétrés par des modules (foncteurs)
Modularité Extensions Suivant les langages de programmation, modules plus avancés : modules imbriqués modules paramétrés par des modules (foncteurs) généricité modules de première classe : peuvent être
RAPPELS SUR LES METHODES HERITEES DE LA CLASSE RACINE Object ET LEUR SPECIALISATION (i.e. REDEFINITION)
CLASSE RACINE Object ancêtre de toutes les classes RAPPELS SUR LES METHODES HERITEES DE LA CLASSE RACINE Object ET LEUR SPECIALISATION (i.e. REDEFINITION) définit donc des méthodes héritées par toutes
La technologie Java Card TM
Présentation interne au CESTI La technologie Java Card TM [email protected] http://dept-info.labri.u-bordeaux.fr/~sauveron 8 novembre 2002 Plan Qu est ce que Java Card? Historique Les avantages
Programmation MacOSX / ios
Programmation MacOSX / ios Master Ingénierie Informatique 2011-2012 Jean-Baptiste.Yunè[email protected] deux extensions objets de C : C++ (Stroustrup) Objective-C (Cox & Love) ajout de constructions à
Polymorphisme, la classe Object, les package et la visibilité en Java... 1
Polymorphisme, la classe Object, les package et la visibilité en Java. Polymorphisme, la classe Object, les package et la visibilité en Java.... 1 Polymorphisme.... 1 Le DownCast... 4 La Classe Object....
Plateforme PAYZEN. Définition de Web-services
Plateforme PAYZEN Définition de Web-services Ordre de paiement Version 1.1 Rédaction, Vérification, Approbation Rédaction Vérification Approbation Nom Date/Visa Nom Date/Visa Nom Date/Visa Lyra-Network
Cours 1 : La compilation
/38 Interprétation des programmes Cours 1 : La compilation Yann Régis-Gianas [email protected] PPS - Université Denis Diderot Paris 7 2/38 Qu est-ce que la compilation? Vous avez tous déjà
Cours intensif Java. 1er cours: de C à Java. Enrica DUCHI LIAFA, Paris 7. Septembre 2009. [email protected]
. Cours intensif Java 1er cours: de C à Java Septembre 2009 Enrica DUCHI LIAFA, Paris 7 [email protected] LANGAGES DE PROGRAMMATION Pour exécuter un algorithme sur un ordinateur il faut le
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
1/46 2/46 Pourquoi? Anne-Cécile Caron Master MAGE - SGBD 1er trimestre 2014-2015 Le concept de transaction va permettre de définir des processus garantissant que l état de la base est toujours cohérent
Cours 6 : Tubes anonymes et nommés
Cours 6 : Tubes anonymes et nommés Mécanisme de communications du système de fichiers I-node associé. Type de fichier: S_IFIFO. Accès au travers des primitives read et write. Les tubes sont unidirectionnels
Utilisation d objets : String et ArrayList
Chapitre 6 Utilisation d objets : String et ArrayList Dans ce chapitre, nous allons aborder l utilisation d objets de deux classes prédéfinies de Java d usage très courant. La première, nous l utilisons
EPREUVE OPTIONNELLE d INFORMATIQUE CORRIGE
EPREUVE OPTIONNELLE d INFORMATIQUE CORRIGE QCM Remarque : - A une question correspond au moins 1 réponse juste - Cocher la ou les bonnes réponses Barème : - Une bonne réponse = +1 - Pas de réponse = 0
PIGOURIER Vincent ANNEE SPECIALE 99/00 RAPPORT DE PROJET : LES THREADS JAVA. Responsable : Serge Rouveyrol
PIGOURIER Vincent ANNEE SPECIALE 99/00 RAPPORT DE PROJET : LES THREADS JAVA Responsable : Serge Rouveyrol 1 I -INTRODUCTION A L'UTILISATION DES THREADS...3 1 - Géneralités et propriétés des threads...3
Programme Compte bancaire (code)
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; Programme Compte bancaire (code) namespace compte_bancaire /// Classe Program public
Notes de cours : bases de données distribuées et repliquées
Notes de cours : bases de données distribuées et repliquées Loïc Paulevé, Nassim Hadj-Rabia (2009), Pierre Levasseur (2008) Licence professionnelle SIL de Nantes, 2009, version 1 Ces notes ont été élaborées
Paginer les données côté serveur, mettre en cache côté client
Paginer les données côté serveur, mettre en cache côté client Vous voulez sélectionner des lignes dans une table, mais celle-ci comporte trop de lignes pour qu il soit réaliste de les ramener en une seule
TD3: tableaux avancées, première classe et chaînes
TD3: tableaux avancées, première classe et chaînes de caractères 1 Lestableaux 1.1 Élémentsthéoriques Déclaration des tableaux Pour la déclaration des tableaux, deux notations sont possibles. La première
Programmation avec des objets : Cours 7. Menu du jour
1 Programmation avec des objets : Cours 7 Menu du jour 1. Retour sur la classe Liste 2. Précisions sur l interface 3. Difficultés dans le cas d erreurs 4. Soulever des exceptions 5. Utilisation des Listes
Systèmes d exploitation Gestion de processus
Systèmes d exploitation Gestion de processus SITE : http://www.sir.blois.univ-tours.fr/ mirian/ Systèmes d exploitation - Mírian Halfeld-Ferrari p. 1/5 Les processus, à quoi ça sert? À faire plusieurs
OS Réseaux et Programmation Système - C5
OS Réseaux et Programmation Système - C5 Rabie Ben Atitallah [email protected] RPC - XDR Rappel RPC: Remote Procedure Call Besoin d un environnement de haut niveau pour le développement
