Comment régler les problèmes de synchronisation? P-A. Champin
|
|
|
- Jean-Sébastien Noël
- il y a 10 ans
- Total affichages :
Transcription
1 S y s t è m e d ' e x p l o i t a t i o n S é a n c e 5 Comment régler les problèmes de synchronisation? P-A. Champin Département Informatique IUT A Université Claude Bernard Lyon S5 - Comment régler les problèmes de synchronisation? - P-A. Champin - IUT A
2 P r o b l é m a t i q u e s Ressource critique Problème des producteurs/consommateurs Problème des lecteurs/rédacteurs Problème des philosophes Exclusion mutuelle au sein du SE S5 - Comment régler les problèmes de synchronisation? - P-A. Champin - IUT A
3 P r o b l é m a t i q u e s Ressource critique Problème des producteurs/consommateurs Problème des lecteurs/rédacteurs Problème des philosophes Exclusion mutuelle au sein du SE S5 - Comment régler les problèmes de synchronisation? - P-A. Champin - IUT A
4 R e s s o u r c e c r i t i q u e E x e m p l e s a n s p r o b l è m e tâche 1 (compte += 1000) tâche 2 (compte -= 500) ressources compte r1 r2 charger (r1, compte) charger (r2, 1000) ajouter (r1, r2) écrire (r1, compte) sauvegarde contexte restauration contexte 0 0 charger (r1, compte) charger (r2, 500) soustraire (r1, r2) écrire (r1, compte) S5 - Comment régler les problèmes de synchronisation? - P-A. Champin - IUT A
5 R e s s o u r c e c r i t i q u e E x e m p l e a v e c u n p r o b l è m e tâche 1 (compte += 1000) tâche 2 (compte -= 500) ressources compte r1 r2 charger (r1, compte) charger (r2, 1000) ajouter (r1, r2) commutation de contexte 0 0 charger (r1, compte) charger (r2, 500) soustraire (r1, r2) écrire (r1, compte) commutation de contexte écrire (r1, compte) S5 - Comment régler les problèmes de synchronisation? - P-A. Champin - IUT A
6 D é f i n i t i o n s a u t o u r d e l a n o t i o n d e r e s s o u r c e c r i t i q u e Une ressource est dite ressource critique lorsque des accès concurrents à cette ressources peuvent résulter dans un état incohérent On parle aussi de situation de compétition (race condition) pour décrire une situation dont l'issue dépend de l'ordre dans lequel les opérations sont effectuées Une section critique est une section de programme manipulant une ressource critique S5 - Comment régler les problèmes de synchronisation? - P-A. Champin - IUT A
7 D é f i n i t i o n : E x c l u s i o n m u t u e l l e Une section de programme est dite atomique lorsqu'elle ne peut pas être interrompue par un autre processus manipulant les mêmes ressources critiques c'est donc une atomicité relative à la ressource Un mécanisme d'exclusion mutuelle sert à assurer l'atomicité des sections critiques relatives à une ressource critique en anglais : mutual exclusion, ou mutex S5 - Comment régler les problèmes de synchronisation? - P-A. Champin - IUT A
8 E x c l u s i o n m u t u e l l e M i s e e n o e u v r e entier compte proc entrer_sc_compte () proc sortir_sc_compte () afficher («Ajout de 1000») entrer_sc_compte () compte += 1000 sortir_sc_compte () afficher («Ajout effectué») afficher («Retrait de 500») entrer_sc_compte () compte -= 500 sortir_sc_compte () afficher («Retrait effectué») S5 - Comment régler les problèmes de synchronisation? - P-A. Champin - IUT A
9 E x c l u s i o n m u t u e l l e C r i t è r e s d ' é v a l u a t i o n Exclusion : deux tâches ne doivent pas se trouver en même temps en SC Progression : une tâche doit pouvoir entrer en SC si aucune autre ne s'y trouve Équité : une tâche ne devrait pas attendre indéfiniment pour entrer SC L'exclusion mutuelle doit fonctionner dans un contexte multi-processeurs S5 - Comment régler les problèmes de synchronisation? - P-A. Champin - IUT A
10 E x c l u s i o n m u t u e l l e P r i n c i p e d ' u n e s o l u t i o n On associe à la ressource un jeton, que les processus peuvent prendre et reposer Seul le processus possédant le jeton devrait manipuler la ressource Donc, si un processus souhaite manipuler la ressource et que le jeton est pris, il doit d'abord attendre que le jeton redevienne disponible Utilisation d'un sémaphore initialisé à 1 S5 - Comment régler les problèmes de synchronisation? - P-A. Champin - IUT A
11 E x c l u s i o n m u t u e l l e E x e m p l e int compte = 2000; sem_t mutex_compte = sem_open("/compte", flags, mode, 1); printf ("Ajout de 1000 \n"); sem_wait (mutex_compte); compte += 1000; sem_post (mutex_compte); printf ("Ajout effectué\n"); printf ("Retrait de 500 \n"); sem_wait (mutex_compte); compte -= 500; sem_post (mutex_compte); printf ("Retrait effectué\n"); S5 - Comment régler les problèmes de synchronisation? - P-A. Champin - IUT A
12 R e m a r q u e s s u r l e p r o b l è m e d e r e s s o u r c e c r i t i q u e Certaines opérations sur la ressource critiques ne nécessitent pas forcément d'exclusion mutuelle exemple : lecture de la valeur du compte (si on accepte que la valeur lue devienne rapidement invalide...) Le mécanisme d'exclusion mutuelle n'est pas une protection, mais une convention entre les processus souhaitant utiliser la ressource sans la corrompre il est toujours possible de manipuler la ressource sans «prendre le jeton» S5 - Comment régler les problèmes de synchronisation? - P-A. Champin - IUT A
13 R e m a r q u e s u r l e s s e c t i o n s c r i t i q u e s ( 1 ) Les sections critiques sont un mal nécessaire : un mal, parce qu'elles empêches le parallélisme qu'on a eu tant de mal à mettre en place... elles réduisent donc les performances nécessaire, parce qu'elles garantissent l'intégrité des ressources critiques Conséquence : lorsqu'on peut les éviter, il faut le faire (structures de données toujours cohérentes) S5 - Comment régler les problèmes de synchronisation? - P-A. Champin - IUT A
14 R e m a r q u e s u r l e s s e c t i o n s c r i t i q u e s ( 2 ) Étant donné qu'un processus en section critique est susceptible d'en bloquer d'autres, il est souhaitable qu'il reste le moins longtemps possible en section critique, et surtout qu'il ne s'y bloque pas. // n'écrivez pas : sem_wait (mutex_compte); printf ("Ajout de 1000 \n"); compte += 1000; sem_post (mutex_compte); // mais écrivez : printf ("Ajout de 1000 \n"); sem_wait (mutex_compte); compte += 100; sem_post (mutex_compte); S5 - Comment régler les problèmes de synchronisation? - P-A. Champin - IUT A
15 D é f i n i t i o n : I n t e r - b l o c a g e Un interblocage (deadlock) esr une situation ou deux processus (ou plus) sont bloqués en attente d'un événement qui doit être produit par l'autre sem_wait (mutex_a); utiliser_ressource(a); sem_wait (mutex_b); utiliser_ressources(a,b); //... sem_wait (mutex_b); utiliser_ressource(b); sem_wait (mutex_a); utiliser_ressources(a,b); //... S5 - Comment régler les problèmes de synchronisation? - P-A. Champin - IUT A
16 I n t e r - b l o c a g e S o l u t i o n p o s s i b l e Une manière d'éviter les inter-blocages consiste à toujours réclamer les ressources dans le même ordre (quitte à libérer une ressource avant de la réclamer à nouveau) sem_wait (mutex_a); utiliser_ressource(a); sem_wait (mutex_b); utiliser_ressources(a,b); //... sem_wait (mutex_b); utiliser_ressource(b); sem_post (mutex_b); sem_wait (mutex_a); sem_wait (mutex_b); utiliser_ressources(a,b); //... S5 - Comment régler les problèmes de synchronisation? - P-A. Champin - IUT A
17 P r o b l é m a t i q u e s Ressource critique Problème des producteurs/consommateurs Problème des lecteurs/rédacteurs Problème des philosophes Exclusion mutuelle au sein du SE S5 - Comment régler les problèmes de synchronisation? - P-A. Champin - IUT A
18 P r o d u c t e u r s - c o n s o m m a t e u r s S c é n a r i o Un ensemble de processus, divisé en deux catégories, partage une zone mémoire Les premiers (producteurs) remplissent la mémoire partagée, avec des éléments la mémoire ne peut contenir qu'un nombre d'éléments limité et connu à l'avance Les seconds (consommateurs) utilisent ces éléments et les retirent de la mémoire Exemple : file d'impression S5 - Comment régler les problèmes de synchronisation? - P-A. Champin - IUT A
19 P r o d u c t e u r s - c o n s o m m a t e u r s I l l u s t r a t i o n P1 P2 a b Zzz... C1 S5 - Comment régler les problèmes de synchronisation? - P-A. Champin - IUT A
20 P r o d u c t e u r s - c o n s o m m a t e u r s I l l u s t r a t i o n P1 Zzz... P2 b a Zzz... C1 S5 - Comment régler les problèmes de synchronisation? - P-A. Champin - IUT A
21 P r o d u c t e u r s - c o n s o m m a t e u r s I l l u s t r a t i o n P1 P2 c a b Zzz... C1 S5 - Comment régler les problèmes de synchronisation? - P-A. Champin - IUT A
22 P r o d u c t e u r s - c o n s o m m a t e u r s I l l u s t r a t i o n Zzz... P1 P2 c d a b C1 S5 - Comment régler les problèmes de synchronisation? - P-A. Champin - IUT A
23 P r o d u c t e u r s - c o n s o m m a t e u r s I l l u s t r a t i o n P1 P2 d a c b C1 S5 - Comment régler les problèmes de synchronisation? - P-A. Champin - IUT A
24 P r o d u c t e u r s - c o n s o m m a t e u r s I l l u s t r a t i o n P1 P2 e a c d b C1 S5 - Comment régler les problèmes de synchronisation? - P-A. Champin - IUT A
25 P r o d u c t e u r s - c o n s o m m a t e u r s I l l u s t r a t i o n Zzz... P1 P2 e f a c d b C1 S5 - Comment régler les problèmes de synchronisation? - P-A. Champin - IUT A
26 P r o d u c t e u r s - c o n s o m m a t e u r s P r o b l è m e Un producteur doit se bloquer lorsque la mémoire partagée est pleine Un consommateur doit se bloquer lorsque la mémoire partagée est vide S5 - Comment régler les problèmes de synchronisation? - P-A. Champin - IUT A
27 P r o d u c t e u r s - c o n s o m m a t e u r s S o l u t i o n p r i n c i p e ( 1 ) Utilisation de deux sémaphores, implémentant les deux critères de blocage l'un représente le nombre de cases libres l'autre représente le nombre de cases occupées Analogie : deux piles de jetons, avec une quantité de jetons constante les jetons passent d'une pile dans une autre lorsqu'une case change d'état S5 - Comment régler les problèmes de synchronisation? - P-A. Champin - IUT A
28 P r o d u c t e u r s - c o n s o m m a t e u r s S o l u t i o n p r i n c i p e ( 2 ) Si les opérations sur la zone mémoire partagée ne sont pas atomiques, il faut les protéger par une section critique troisième sémaphore S5 - Comment régler les problèmes de synchronisation? - P-A. Champin - IUT A
29 P r o d u c t e u r s - c o n s o m m a t e u r s S o l u t i o n A l g o r i t h m e sémaphore pleines(0), vides(n), mutex (1) élément tab[n] proc Producteur : tant que VRAI: élément e produire() sem_wait(vides) sem_wait(mutex) ajouter(e, tab) sem_post(mutex) sem_post(pleines) proc Consommateur : tant que VRAI: sem_wait(pleines) sem_wait(mutex) élément e retirer(tab) sem_post(mutex) sem_post(vides) consommer(e) S5 - Comment régler les problèmes de synchronisation? - P-A. Champin - IUT A
30 P r o d u c t e u r s - c o n s o m m a t e u r s R e m a r q u e s Dans l'algorithme précédent, l'ordre dans lequel les sémaphores sont utilisés est primordial, sans quoi on risque un inter-blocage Les opérations de production et de consommation à proprement parler doivent être en dehors des sections critiques sans quoi seul un processus pourrait s'exécuter à un moment donné De même, elles doivent être en dehors du «passage de jeton» entre pleines et vides S5 - Comment régler les problèmes de synchronisation? - P-A. Champin - IUT A
31 P r o b l é m a t i q u e s Ressource critique Problème des producteurs/consommateurs Problème des lecteurs/rédacteurs Problème des philosophes Exclusion mutuelle au sein du SE S5 - Comment régler les problèmes de synchronisation? - P-A. Champin - IUT A
32 L e c t e u r s - r é d a c t e u r s S c é n a r i o Un ensemble de processus, divisé en deux catégories, partage une zone mémoire Certains processus (les lecteurs) font des accès en lecture seule à cette zone D'autres processus (les rédacteurs) modifient le contenu de cette zone NB : on parle parfois d'écrivains plutôt que de rédacteurs S5 - Comment régler les problèmes de synchronisation? - P-A. Champin - IUT A
33 L e c t e u r s - r é d a c t e u r s P r o b l è m e Lorsqu'un rédacteur accède à la mémoire partagée, aucune autre processus (qu'il soit lecteur ou rédacteur) ne doit y avoir accès problème d'exclusion mutuelle classique En revanche, les lecteurs peuvent être plusieurs à utiliser la zone en même temps, cela ne pose pas de problème S5 - Comment régler les problèmes de synchronisation? - P-A. Champin - IUT A
34 L e c t e u r s - r é d a c t e u r s S o l u t i o n - P r i n c i p e On protège la mémoire partagée par une exclusion mutuelle, mais... les lecteurs n'ont besoin de cette exclusion mutuelle que si aucun autre lecteur n'utilise la mémoire ; pour le vérifier, ils utilisent un compteur (nombre de lecteurs en train d'utiliser la zone), lui aussi protégé par une exclusion mutuelle S5 - Comment régler les problèmes de synchronisation? - P-A. Champin - IUT A
35 L e c t e u r s - r é d a c t e u r s S o l u t i o n A l g o r i t h m e sémaphore mutex_m(1), mutex_c(1) entier c // nombre de lecteurs proc Rédacteur : sem_wait(mutex_m) écrire() sem_post(mutex_m) proc Lecteur : sem_wait(mutex_c) si c = 0 alors sem_wait(mutex_m) c c + 1 sem_post(mutex_c) lire() sem_wait(mutex_c) si c = 1 alors sem_post(mutex_m) c c - 1 sem_post(mutex_c) S5 - Comment régler les problèmes de synchronisation? - P-A. Champin - IUT A
36 L e c t e u r s - r é d a c t e u r s R e m a r q u e s Le lecteur qui prend le jeton de mutex_m n'est pas forcément celui qui le rend On note que les lecteurs peuvent parfois se bloquer dans la section critique du compteur c. Cela peut-il créer des inter-blocages? L'algorithme proposé fonctionne, mais n'assure pas l'équité : un rédacteur peut attendre indéfiniment avant d'avoir accès à la mémoire (famine) Comment le modifier pour assurer l'équité? S5 - Comment régler les problèmes de synchronisation? - P-A. Champin - IUT A
37 P r o b l é m a t i q u e s Ressource critique Problème des producteurs/consommateurs Problème des lecteurs/rédacteurs Problème des philosophes Exclusion mutuelle au sein du SE S5 - Comment régler les problèmes de synchronisation? - P-A. Champin - IUT A
38 P r o b l è m e d e s p h i l o s o p h e s S c é n a r i o ( D i j k s t r a ) Cinq philosophes passent leur vie à penser et manger autour d'une table Pour manger, ils ont besoin de deux fourchettes, mais il n'y a que cinq fourchettes Illustration : Benjamin Esham S5 - Comment régler les problèmes de synchronisation? - P-A. Champin - IUT A
39 P r o b l è m e d e s p h i l o s o p h e s P r o b l è m e Proposer un algorithme qui évite : les inter-blocages la famine Mauvaise solution : chaque philosophe, lorsqu'il a faim, prend la fourchette de gauche, puis celle de droite, mange, puis les repose S5 - Comment régler les problèmes de synchronisation? - P-A. Champin - IUT A
40 P r o b l è m e d e s p h i l o s o p h e s S o l u t i o n - P r i n c i p e Chaque philosophe a trois états : «je pense», «j'ai faim», «je mange» par lesquels il passe toujours dans cet ordre Lorsqu'il a faim, un philosophe ne peut manger que si ses deux voisins ne mangent pas, sinon attend Lorsqu'il termine de manger, le philosophe réveille ses voisins et se remet à penser S5 - Comment régler les problèmes de synchronisation? - P-A. Champin - IUT A
41 P r o b l è m e d e s p h i l o s o p h e s S o l u t i o n - A l g o r i t h m e proc CommenceManger(id) : sem_wait(mutex) états[id] FAIM ok état[id-1] MANGE et état[id+1] MANGE si ok alors état[id] MANGE sem_post(mutex) sinon sem_post(mutex) sem_wait(réveils[id]) sémaphore mutex(1), réveils[n] // init 0 entier états[n] // init PENSE proc FinitManger(id) : sem_wait(mutex) états[id] PENSE si état[id-1] = FAIM et état[id-2] MANGE alors état[id-1] MANGE sem_post(réveils[id-1]) // idem pour i+1 et i+2 sem_post(mutex) S5 - Comment régler les problèmes de synchronisation? - P-A. Champin - IUT A
42 P r o b l è m e d e s p h i l o s o p h e s R e m a r q u e s L'algorithme proposé prévient les inter-blocages, mais pas la famine Pour l'améliorer, une solution consiste à ne réveiller un voisin que si son autre voisin (id±2) n'est pas dans l'état FAIM depuis trop longtemps / depuis plus longtemps que lui S5 - Comment régler les problèmes de synchronisation? - P-A. Champin - IUT A
43 P r o b l é m a t i q u e s Ressource critique Problème des producteurs/consommateurs Problème des lecteurs/rédacteurs Problème des philosophes Exclusion mutuelle au sein du SE S5 - Comment régler les problèmes de synchronisation? - P-A. Champin - IUT A
44 B e s o i n Les appels systèmes manipules de nombreuses structures Exemple : PCB, table des fichiers ouverts, descripteur de fichier ouvert, table de pages, etc... Dans un système multi-processeurs, plusieurs appels systèmes peuvent s'exécuter en même temps nécessité d'exclusion mutuelle au sein des appels systèmes S5 - Comment régler les problèmes de synchronisation? - P-A. Champin - IUT A
45 P r o b l è m e ( 1 ) Implémentation naïve d'un sémaphore Problème : les deux algorithmes sont des sections critiques pour le compteur c et la file d'attente des processus bloqués proc sem_wait(sem) : si sem.c = 0 alors bloquer le processus finsi sem.c sem.c - 1 proc sem_post(sem) : sem.c sem.c + 1 si un processus est bloqué en attente du sémaphore alors débloquer ce processus finsi S5 - Comment régler les problèmes de synchronisation? - P-A. Champin - IUT A
46 P r o b l è m e ( 2 ) Protection de la section critique par une exclusion mutuelle : il faut utiliser autre chose qu'un sémaphore! proc sem_wait(sem) : entrer_en_sc() si sem.c = 0 alors sortir_de_sc() bloquer le processus sinon sem.c sem.c - 1 sortir_de_sc() finsi proc sem_post(sem) : entrer_en_sc() sem.c sem.c + 1 si un processus est bloqué en attente du sémaphore alors débloquer ce processus sem.c sem.c - 1 finsi sortir_de_sc() S5 - Comment régler les problèmes de synchronisation? - P-A. Champin - IUT A
47 A t t e n t e a c t i v e Attente active : le processeur est occupé à attendre par opposition à un processus bloqué, qui n'utilise pas le processeur Implémentation naïve de l'exclusion mutuelle n'assure pas l'exclusion... proc enter_sc() : tant que verrou faire <rien> fintant verrou VRAI global booléen verrou = FAUX proc sortir_sc() : verrou FAUX S5 - Comment régler les problèmes de synchronisation? - P-A. Champin - IUT A
48 S o l u t i o n m a t é r i e l l e L'instruction processeur TEST_AND_SET consulte et change une variable en une seule action (atomique) si la variable est à 1, elle retourne 1 si la variable est à 0, elle la met à 1 et retourne 0 Supprime la situation de compétition entre le test de la boucle et l'affectation du verrou proc enter_sc() : tant que TEST_AND_SET(verrou) faire <rien> fintant S5 - Comment régler les problèmes de synchronisation? - P-A. Champin - IUT A
49 S o l u t i o n s l o g i c i e l l e s Il existe des solutions purement logicielles (i.e. qui ne nécessitent pas l'existence d'instruction atomique pour tester et modifier une variable) algorithme de Peterson algorithme de la Boulangerie Mécanismes plus complexe qu'un simple verrou, pour ne rien avoir à faire après l'attente active tableau de verrous notion de tour S5 - Comment régler les problèmes de synchronisation? - P-A. Champin - IUT A
50 I m p l é m e n t a t i o n e f f e c t i v e d u s é m a p h o r e ( 1 ) proc sem_wait(sem) : entrer_en_sc() si sem.c = 0 alors sortir_de_sc() bloquer le processus sinon sem.c sem.c - 1 sortir_de_sc() finsi proc sem_post(sem) : entrer_en_sc() sem.c sem.c + 1 si un processus est bloqué en attente du sémaphore alors débloquer ce processus sem.c sem.c - 1 finsi sortir_de_sc() S5 - Comment régler les problèmes de synchronisation? - P-A. Champin - IUT A
51 I m p l é m e n t a t i o n e f f e c t i v e d u s é m a p h o r e ( 2 ) proc sem_wait(sem) : entrer_en_sc() si sem.c = 0 alors masquer_interruption() sem.f.ajouter(processus) processus.état BLOQUÉ sortir_de_sc() dé-masquer_interruption() rendre_la_main() sinon sem.c sem.c - 1 sortir_de_sc() finsi proc sem_post(sem) : entrer_en_sc() sem.c sem.c + 1 si non f.est_vide() alors p sem.f.retirer() p.état ÉLIGIBLE sem.c sem.c - 1 finsi sortir_de_sc() S5 - Comment régler les problèmes de synchronisation? - P-A. Champin - IUT A
52 E n c o n c l u s i o n Les sémaphores permettent de régler de nombreux problèmes de synchronisation entre processus Problèmes classiques Au sein du système d'exploitation, des mécanismes de synchronisation «bas niveau» sont également nécessaires : attente active avec TEST_AND_SET S5 - Comment régler les problèmes de synchronisation? - P-A. Champin - IUT A
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
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
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
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
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
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
É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
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
Gestion des processus
65 La Gestion des Processus 1 Définitions, exemples 2. Politiques d'allocation du processeur 3. Synchronisation des processus 66 Programme : Un programme est une suite figée d'instructions, un ensemble
Chapitre 4 : Exclusion mutuelle
Chapitre 4 : Exclusion mutuelle Pierre Gançarski Juillet 2004 Ce support de cours comporte un certain nombre d erreurs : je décline toute responsabilité quant à leurs conséquences sur le déroulement des
Série TD 3. Exercice 4.1. Exercice 4.2 Cet algorithme est destiné à prédire l'avenir, et il doit être infaillible! Exercice 4.3. Exercice 4.
Série TD 3 Exercice 4.1 Formulez un algorithme équivalent à l algorithme suivant : Si Tutu > Toto + 4 OU Tata = OK Alors Tutu Tutu + 1 Tutu Tutu 1 ; Exercice 4.2 Cet algorithme est destiné à prédire l'avenir,
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
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
L exclusion mutuelle distribuée
L exclusion mutuelle distribuée L algorithme de L Amport L algorithme est basé sur 2 concepts : L estampillage des messages La distribution d une file d attente sur l ensemble des sites du système distribué
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
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
Complexité. Licence Informatique - Semestre 2 - Algorithmique et Programmation
Complexité Objectifs des calculs de complexité : - pouvoir prévoir le temps d'exécution d'un algorithme - pouvoir comparer deux algorithmes réalisant le même traitement Exemples : - si on lance le calcul
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
Introduction à la programmation concurrente
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
Cours Bases de données 2ème année IUT
Cours Bases de données 2ème année IUT Cours 12 : Concurrence d accès Anne Vilnat http://www.limsi.fr/individu/anne/cours Plan 1 Accès concurrents Définitions Verrous Collisions Niveaux de cohérence Blocage
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
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
Guide de démarrage rapide Centre de copies et d'impression Bureau en Gros en ligne
Guide de démarrage rapide Centre de copies et d'impression Bureau en Gros en ligne Aperçu du Centre de copies et d'impression Bureau en Gros en ligne Pour accéder à «copies et impression Bureau en Gros
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
Programmation Objet - Cours II
Programmation Objet - Cours II - Exercices - Page 1 Programmation Objet - Cours II Exercices Auteur : E.Thirion - Dernière mise à jour : 05/07/2015 Les exercices suivants sont en majorité des projets à
Programmation C++ (débutant)/instructions for, while et do...while
Programmation C++ (débutant)/instructions for, while et do...while 1 Programmation C++ (débutant)/instructions for, while et do...while Le cours du chapitre 4 : le for, while et do...while La notion de
TP n 2 Concepts de la programmation Objets Master 1 mention IL, semestre 2 Le type Abstrait Pile
TP n 2 Concepts de la programmation Objets Master 1 mention IL, semestre 2 Le type Abstrait Pile Dans ce TP, vous apprendrez à définir le type abstrait Pile, à le programmer en Java à l aide d une interface
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
gestion des processus La gestion des processus
1 La Pseudo parallélisme 2 Plusieurs programmes en mémoire Le processeur exécute les instructions tantôt pour l'un tantôt pour l'autre P1 P2 programme de supervision Vu de l'utilisateur => programmes en
Bases de données avancées Concurrence d'accès et reprise
Bases de données avancées Concurrence d'accès et reprise Dan VODISLAV Université de Cergy-Pontoise Master Informatique M1 Cours BDA Plan La notion de transaction Les problèmes de la concurrence Problèmes
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
Pour signifier qu'une classe fille hérite d'une classe mère, on utilise le mot clé extends class fille extends mère
L'héritage et le polymorphisme en Java Pour signifier qu'une classe fille hérite d'une classe mère, on utilise le mot clé extends class fille extends mère En java, toutes les classes sont dérivée de la
Systemes d'exploitation des ordinateurs
! " #$ % $ &' ( $ plan_ch6_m1 Systemes d'exploitation des ordinateurs Conception de Systèmes de Gestion de la Mémoire Centrale Objectifs 1. Conception de systèmes paginés 2. Conception des systèmes segmentés
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 -
Trousse de sécurité d'alarme - NVR
Trousse de sécurité d'alarme - NVR FR Tous les capteurs de mouvement, capteurs de fenêtre/porte, télécommandes et sirènes sans fil sont jumelés avec une antenne USB au cours de la fabrication. Toutefois,
Définition du compte courant
Définition du compte courant Un compte courant n est pas un compte bancaire, mais un simple compte dans le système comptable de l Office (SAP/R3), qui est inclus dans le grand livre des comptes clients.
Cours d introduction à l informatique. Partie 2 : Comment écrire un algorithme? Qu est-ce qu une variable? Expressions et instructions
Cours d introduction à l informatique Partie 2 : Comment écrire un algorithme? Qu est-ce qu une variable? Expressions et instructions Qu est-ce qu un Une recette de cuisine algorithme? Protocole expérimental
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
Cours Programmation Système
Cours Programmation Système Filière SMI Semestre S6 El Mostafa DAOUDI Département de Mathématiques et d Informatique, Faculté des Sciences Université Mohammed Premier Oujda [email protected] Février
Guide d'utilisation du Serveur USB
Guide d'utilisation du Serveur USB Copyright 20-1 - Informations de copyright Copyright 2010. Tous droits réservés. Avis de non responsabilité Incorporated ne peut être tenu responsable des erreurs techniques
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
Les diagrammes de modélisation
L approche Orientée Objet et UML 1 Plan du cours Introduction au Génie Logiciel L approche Orientée Objet et Notation UML Les diagrammes de modélisation Relations entre les différents diagrammes De l analyse
Chapitre 1 : Introduction aux bases de données
Chapitre 1 : Introduction aux bases de données Les Bases de Données occupent aujourd'hui une place de plus en plus importante dans les systèmes informatiques. Les Systèmes de Gestion de Bases de Données
1. Contexte général page 2. 2. Le compte auprès de la BCGE...page 2 2.1 La procuration 2.2 Les accès e-banking 2.3 Le bon de retrait 2.
1 REPUBLIQUE ET CANTON DE GENEVE Département de l'instruction publique, de la culture et du sport Enseignement primaire Direction générale MANUEL POUR LA TENUE DES COMPTES ÉCOLES COMPTES BCGE - TIERS UNIQUE
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
Messages d'erreurs. Redémarrez votre PC en cliquant sur Démarrer, en sélectionnant ensuite Arrêter puis en cochant Redémarrer
Messages d'erreurs Erreur 602 Vous essayez de vous connecter à Internet. L'erreur n 602 apparaît et il vous est impossible de vous connecter. L'erreur 602 est souvent issue de l'utilisation de l'accès
CEG4566/CSI4541 Conception de systèmes temps réel
CEG4566/CSI4541 Conception de systèmes temps réel Chapitre 6 Vivacité, sécurité (Safety), fiabilité et tolérance aux fautes dans les systèmes en temps réel 6.1 Introduction générale aux notions de sécurité
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.
Algorithmique et Programmation, IMA
Algorithmique et Programmation, IMA Cours 2 : C Premier Niveau / Algorithmique Université Lille 1 - Polytech Lille Notations, identificateurs Variables et Types de base Expressions Constantes Instructions
Création d'un questionnaire (sondage)
Création d'un questionnaire (sondage) Le but de ce petit tuto est d'avoir les séquences pas à pas pour la création d'un questionnaire de façon à ne pas devoir rechercher la manière de procéder si l'outil
Systèmes Répartis. Mr. Mehrez Boulares, Mr. Nour Ben Yahia 2013-2014
Systèmes Répartis Mr. Mehrez Boulares, Mr. Nour Ben Yahia 2013-2014 Introduction aux systèmes répartis 2 Les ordinateurs ont subi des changements incroyables depuis leur mise en opération vers 1945: plus
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
I. Introduction aux fonctions : les fonctions standards
Chapitre 3 : Les fonctions en C++ I. Introduction aux fonctions : les fonctions standards A. Notion de Fonction Imaginons que dans un programme, vous ayez besoin de calculer une racine carrée. Rappelons
Traitement de texte : Quelques rappels de quelques notions de base
Traitement de texte : Quelques rappels de quelques notions de base 1 Quelques rappels sur le fonctionnement du clavier Voici quelques rappels, ou quelques appels (selon un de mes profs, quelque chose qui
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
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
Logiciel SCRATCH FICHE 02
1. Reprise de la fiche 1: 1.1. Programme Figure : Logiciel SCRATCH FICHE 02 SANS ORDINATEUR : Dessiner à droite le dessin que donnera l'exécution de ce programme : Unité : 50 pas : Remarque : vous devez
1. Création d'un état... 2. 2. Création d'un état Instantané Colonnes... 3. 3. Création d'un état Instantané Tableau... 4
1. Création d'un état... 2 2. Création d'un état Instantané Colonnes... 3 3. Création d'un état Instantané Tableau... 4 4. Création d'un état avec plusieurs tables... 9 5. Modifier la structure d'un état...11
Cours de Base de Données Cours n.12
Cours de Base de Données Cours n.12 Gestion des transactions : contrôle de concurrence Elisabetta De Maria - http://www.i3s.unice.fr/ edemaria/ UFR Sciences et Laboratoire I3S, CNRS 2013-2014 Université
Le chiffre est le signe, le nombre est la valeur.
Extrait de cours de maths de 6e Chapitre 1 : Les nombres et les opérations I) Chiffre et nombre 1.1 La numération décimale En mathématique, un chiffre est un signe utilisé pour l'écriture des nombres.
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
Algorithmique avec Algobox
Algorithmique avec Algobox 1. Algorithme: Un algorithme est une suite d instructions qui, une fois exécutée correctement, conduit à un résultat donné Un algorithme doit contenir uniquement des instructions
Le langage C. Séance n 4
Université Paris-Sud 11 Institut de Formation des Ingénieurs Remise à niveau INFORMATIQUE Année 2007-2008 Travaux pratiques d informatique Le langage C Séance n 4 But : Vous devez maîtriser à la fin de
Partie 7 : Gestion de la mémoire
INF3600+INF2610 Automne 2006 Partie 7 : Gestion de la mémoire Exercice 1 : Considérez un système disposant de 16 MO de mémoire physique réservée aux processus utilisateur. La mémoire est composée de cases
Module SMS pour Microsoft Outlook MD et Outlook MD Express. Guide d'aide. Guide d'aide du module SMS de Rogers Page 1 sur 40 Tous droits réservés
Module SMS pour Microsoft Outlook MD et Outlook MD Express Guide d'aide Guide d'aide du module SMS de Rogers Page 1 sur 40 Table des matières 1. Exigences minimales :...3 2. Installation...4 1. Téléchargement
Chapitre 4 Pierre, papier, ciseaux
Python 3 : objectif jeux Chapitre 4 Chapitre 4 Pierre, papier, ciseaux (version graphique) 4.1. Thèmes abordés dans ce chapitre Le module tkinter : Label, Button Fenêtre Événements Réceptionnaire d'événements
Algorithmique et structures de données I
Algorithmique et structures de données I Riadh Ben Messaoud Université 7 novembre à Carthage Faculté des Sciences Économiques et de Gestion de Nabeul 1ère année Licence Fondamentale IAG 1ère année Licence
Algorithmes de recherche
Algorithmes de recherche 1 Résolution de problèmes par recherche On représente un problème par un espace d'états (arbre/graphe). Chaque état est une conguration possible du problème. Résoudre le problème
LES TOUT PREMIERS PAS
DESMODO, un logiciel de gestion d idées http://www.desmodo.net/ LES TOUT PREMIERS PAS Desmodo est un logiciel (libre) qui permet, entre autre, de visualiser et de synthétiser, de manière organisée, sous
Utiliser Subversion (SVN) avec Tortoise
Utiliser Subversion (SVN) avec Tortoise (source: Jonathan Petitcolas - http://www.jonathan-petitcolas.com/utilisersubversion-svn-avec-tortoise/) Initialement destiné à mes associés, j'ai décidé de vous
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
Service Info 2012 17 10 Destinataires... Centres agréés Date... 7 septembre 2012 Produit/système... Chronotachygraphe numérique DTCO Page...
www.vdo.fr/extranet Service Info 2012 17 10 Destinataires... Centres agréés Date... 7 septembre 2012 Produit/système... Chronotachygraphe numérique DTCO Page... 1/6 Objet... CODES ERREURS DTCO 1381...
EXTRACTION ET RÉINTÉGRATION DE COMPTA COALA DE LA PME VERS LE CABINET
EXTRACTION ET RÉINTÉGRATION DE COMPTA COALA DE LA PME VERS LE CABINET Les extractions et réintégrations de fichiers permettent l'échange de comptabilité entre une PME et le Cabinet. Lorsque la comptabilité
CHAPITRE VIII : Les circuits avec résistances ohmiques
CHAPITRE VIII : Les circuits avec résistances ohmiques VIII. 1 Ce chapitre porte sur les courants et les différences de potentiel dans les circuits. VIII.1 : Les résistances en série et en parallèle On
CPLN 20/08/2009 MBO Service ICT et Pédagogie
La clé USB Présentation De première vue, une clé USB est un simple "morceau de plastique". Hors, elle est très utile et de plus en plus utilisée. Elle permet de stocker des fichiers (et dossiers) tout
1. Introduction... 2. 2. Création d'une macro autonome... 2. 3. Exécuter la macro pas à pas... 5. 4. Modifier une macro... 5
1. Introduction... 2 2. Création d'une macro autonome... 2 3. Exécuter la macro pas à pas... 5 4. Modifier une macro... 5 5. Création d'une macro associée à un formulaire... 6 6. Exécuter des actions en
TP : Shell Scripts. 1 Remarque générale. 2 Mise en jambe. 3 Avec des si. Systèmes et scripts
E3FI ESIEE Paris Systèmes et scripts B. Perret TP : Shell Scripts 1 Remarque générale Lorsque vous cherchez des informations sur Internet, n'oubliez pas que langage de shell script que nous avons vu correspond
TRUECRYPT SUR CLEF USB ( Par Sébastien Maisse 09/12/2007 )
TRUECRYPT SUR CLEF USB ( Par Sébastien Maisse 09/12/2007 ) Voici un petit document concernant d'un espace crypté sur une clef usb en utilisant le logiciel TRUECRYPT. Ce dernier est gratuit et disponible
Définition des Webservices Ordre de paiement par email. Version 1.0
Définition des Webservices Ordre de paiement par email Version 1.0 Rédaction, Vérification, Approbation Rédaction Vérification Approbation Nom Date/Visa Nom Date/Visa Nom Date/Visa Historique du document
La sauvegarde (backup) de votre comptabilité a pour but de vous permettre de retrouver vos données si un incident est survenu.
Logiciels concernés Ciel Compta Premium, Evolution et Réseau. Depuis la version 10.xx jusqu'à la version 13.xx Sauvegarde Remarque préliminaire La sauvegarde (backup) de votre comptabilité a pour but de
Correction TD algorithmique
Affectation Correction TD algorithmique Exercice 1 algo affect1b b 5 a b+1 b 2 Il vaut faire passer la notion de variable et la notion de stockage mémoire. Une variable n a donc pas d historique et à un
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
Chap III : Les tableaux
Chap III : Les tableaux Dans cette partie, on va étudier quelques structures de données de base tels que : Les tableaux (vecteur et matrice) Les chaînes de caractères LA STRUCTURE DE TABLEAU Introduction
P our appeler : Décrochez le combiné et composez le numéro OU Composez le numéro et décrochez le combiné
Appareil analogique Meridian Fonctions du système téléphonique Numéro d'appel Haut parleur Touche de libération Touche de garde Touche de commande de volume Indicateur ICL Voyant de message en attente
TP3 : Manipulation et implantation de systèmes de fichiers 1
École Normale Supérieure Systèmes et réseaux Année 2012-2013 TP3 : Manipulation et implantation de systèmes de fichiers 1 1 Répertoire de travail courant Le but de l exercice est d écrire une commande
Cours d Informatique
Cours d Informatique 1ère année SM/SMI 2007/2008, Info 2 Département de Mathématiques et d Informatique, Université Mohammed V [email protected] [email protected] 2007/2008 Info2, 1ère année SM/SMI 1
UTILISATION DE LA BORNE PAR LE CLIENT
Page1 UTILISATION DE LA BORNE PAR LE CLIENT Achat de carte de lavage en carte bancaire Page 3 et 4 Achat de carte de lavage en billet Page 5 et 6 Rechargement de la carte de lavage en carte bancaire Page
Vers l'ordinateur quantique
Cours A&G Vers l'ordinateur quantique Données innies On a vu dans les chapîtres précédents qu'un automate permet de représenter de manière nie (et même compacte) une innité de données. En eet, un automate
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
Seance 2: En respectant la méthode de programmation par contrat, implémentez les autres fonctions de jeu.
Seance 2: Complétion du code de jeu. (durée max: 2h) Mot clé const et pointeurs: En respectant la méthode de programmation par contrat, implémentez les autres fonctions de jeu. Implémentez jeu_recupere_piece
Cours 1 : Qu est-ce que la programmation?
1/65 Introduction à la programmation Cours 1 : Qu est-ce que la programmation? Yann Régis-Gianas [email protected] Université Paris Diderot Paris 7 2/65 1. Sortez un appareil qui peut se rendre
Les différents types de données et leurs opérations de base
Séquence 2 Les différents types de données et leurs opérations de base Contenu Présentation générale... 21 Partie 1 Les 3 familles de données et l'opération d'affectation... 22 1. Les trois familles de
Le module Supply Chain pour un fonctionnement en réseau
Prélude 7 ERP Le module Supply Chain pour un fonctionnement en réseau Gérard Baglin Septembre 2008 Sommaire Chapitre 1 Le mode de fonctionnement en réseau de Prélude 7... 1 Le principe des jeux en temps
LE PROBLEME DU PLUS COURT CHEMIN
LE PROBLEME DU PLUS COURT CHEMIN Dans cette leçon nous définissons le modèle de plus court chemin, présentons des exemples d'application et proposons un algorithme de résolution dans le cas où les longueurs
1/24. I passer d un problème exprimé en français à la réalisation d un. I expressions arithmétiques. I structures de contrôle (tests, boucles)
1/4 Objectif de ce cours /4 Objectifs de ce cours Introduction au langage C - Cours Girardot/Roelens Septembre 013 Du problème au programme I passer d un problème exprimé en français à la réalisation d
Réplication des données
Réplication des données Christelle Pierkot FMIN 306 : Gestion de données distribuées Année 2009-2010 Echange d information distribuée Grâce à un serveur central Une seule copie cohérente Accès à distance
DAns un système d exploitation multiprogrammé en temps partagé, plusieurs
Chapitre 6 Synchronisation des processus DAns un système d exploitation multiprogrammé en temps partagé, plusieurs processus s exécutent en pseudo-parallèle ou en parallèle et partagent des objets (mémoires,
Timy. Programme Doublage ("Backup") Français
Timy Programme Doublage ("Backup") Français Table des matières 1. Clavier... 3 2. Fonctionnement... 4 2.1. Mise en maeche et arrêt du Timy... 4 2.1.1. Mise en marche... 4 2.1.2. Arrêt... 4 3. Utilisation
