Cours #2 Synchronisation dans un OS multitâches
|
|
- Claire Sarah Fortier
- il y a 8 ans
- Total affichages :
Transcription
1 ELE- Ordinateurs et programmation système Cours #2 Synchronisation dans un OS multitâches Bruno De Kelper Site internet : Cours # 2 ELE - Ordinateurs et programmation système 1 Plan d aujourd hui 1. Introduction - synchronisation du noyau 1. Notions de base 1. Concurrence, conditions de course et synchronisation 2. Région critique et opérations atomiques. Verrou et contention. Inter-blocage et auto-blocage 2. Protection des ressources 1. Quand le faire? 2. Quoi protéger?. Catégorie de protection Opérations atomiques 2. Verrou tournant et sémaphore. Variables de terminaison. Désactivation de la préemption du noyau 5. Séquence d exécution et barrières 6. Verrou tournant et sémaphore «lecteur / écrivain». Verrous séquentiels Cours # 2 ELE - Ordinateurs et programmation système 2 Cours # 2 ELE - Ordinateurs et programmation système 1
2 Introduction - synchronisation du noyau Notions de base Protéger l accès concurrent aux ressources partagées est particulièrement important dans les systèmes multiprocesseurs Concurrence, conditions de course et synchronisation Concurrence : Même processeur Pseudo-concurrence - Dans un système multitâches préemptif, une tâche peut être préemptée par une autre tâche plus prioritaire. - Une tâche peut être interrompue par une interruption asynchrone. ISR interruption préemption Plusieurs processeurs Vrai-concurrence - Plusieurs tâches, placées sur différents processeurs, peuvent vouloir accéder à la même ressource. accès Ressource Ressource accès CPU-B Cours # 2 ELE - Ordinateurs et programmation système Introduction - synchronisation du noyau Concurrence, conditions de course et synchronisation Concurrence : La concurrence dans le noyau - Les interruptions se produisent de façon asynchrone. ISR - Un Softirq ou un Tasklet peut être démarré ou cédulé n importe quand. Softirq Tasklet - Une tâche-noyau peut préempter une autre tâche-noyau moins prioritaire. - Une tâche-noyau peut s endormir (se placer en attente d un événement). - Plusieurs processeurs peuvent exécuter des tâches-noyau en même temps. Zzzz Ressource CPU-B Cours # 2 ELE - Ordinateurs et programmation système Cours # 2 ELE - Ordinateurs et programmation système 2
3 Introduction - synchronisation du noyau Concurrence, conditions de course et synchronisation Ressources : - Processeur : Temps d exécution - Mémoire : Données (variable simple, structures, tableaux, ) - Périphériques : Disque (fichiers, matériel), Entrées/Sorties (écran, clavier, canaux de communication, ), Matériel (contrôleur d interruptions, compteurs, horloge, ) Conditions de course : - Lorsque plus qu un morceau de code, une tâche, veut utiliser la même ressource. - Seulement une tâche peut utiliser la ressource à un instant donné. - La première arrivée? Ressource Cours # 2 ELE - Ordinateurs et programmation système 5 Introduction - synchronisation du noyau Concurrence, conditions de course et synchronisation Collision : Par exemple : Lit X ++ Écrit X Lorsque plus d un tâche accède à une ressource en même temps. Supposons qu on veux compter le nombre de fois total que 2 tâches s exécutent, à l aide d un compteur X. Ce qu on voudrait qu il arrive Mémoire X CPU-B Lit X ++ Écrit X Lit X ++ Écrit X Ce qu il arrive en fait Mémoire X CPU-B Lit X ++ Écrit X Et cela peut arriver aussi avec des tâches sur un même processeur Cours # 2 ELE - Ordinateurs et programmation système 6 Cours # 2 ELE - Ordinateurs et programmation système
4 Introduction - synchronisation du noyau Concurrence, conditions de course et synchronisation Synchronisation : - Il s agit de s assurer que l accès aux ressources est contrôlé. - Les tâches peuvent utiliser la ressource à tour de rôle. - La synchronisation est une stratégie pour permettre l accès à une ressource : - Premier arrivé? - Plus rapide d exécution? - Plus prioritaire? - Besoin de plusieurs ressources? Pour l accès au processeur, c est l ordonnanceur qui s en occupe Priorité Appelsystème Tranche de temps Attente sur un verrou CPU Tâche 5 Ordonnanceur Cours # 2 ELE - Ordinateurs et programmation système Introduction - synchronisation du noyau Région critique et opérations atomiques Synchronisation : Pour le reste, il faut prévoir des mécanismes d accès Mutex Sémaphore Lecteur / écrivain Variable de terminaison Sémaphore Désactivation de la préemption Ressource Spin lock Verrou séquentiel Opération atomique Spin lock Lecteur / écrivain Cours # 2 ELE - Ordinateurs et programmation système Cours # 2 ELE - Ordinateurs et programmation système
5 Introduction - synchronisation du noyau Région critique et opérations atomiques Région critique : - Morceau de code qui accède à une ressource partagée. Région critique Lit X ++ Écrit X Mémoire X Code ou opération atomique : - Morceau de code qui s exécute en une seule fois, sans aucune interruption. Opération atomique X++ Mémoire X Les opérations sont faites en une fois comme si s était une seule opération Cours # 2 ELE - Ordinateurs et programmation système 9 Introduction - synchronisation du noyau 1.1. Verrou et Contention Verrou : - C est un mécanisme qui permet de capturer une ressource afin d être seul à pouvoir l utiliser. Contention : - Lorsqu un verrou appartient à une tâche et que d autres tâches essayent de le capturer. Demande Utilise Ressource A (Disponible) Ressource A (Verrouillée) - On parle de contention élevée lorsque : - Un verrou est capturer fréquemment. - Un verrou est tenu pendant longtemps. - Une contention élevée devient un goulot d étranglement pour le système. Libère Ressource A (Disponible) Défaut de programmation Cours # 2 ELE - Ordinateurs et programmation système 10 Cours # 2 ELE - Ordinateurs et programmation système 5
6 Introduction - synchronisation du noyau 1.1. Verrou et Contention Tâche-usager : - Une tâche-usager qui tient un verrou peut être préemptée ou interrompue. ISR Tâche-noyau : - Une tâche-noyau qui tient un verrou ne peut pas être préemptée. - Une tâche-noyau peut être interrompue ISR X Cours # 2 ELE - Ordinateurs et programmation système 11 Introduction - synchronisation du noyau Inter-blocage et auto-blocage Inter-blocage : - Deux tâches ou plus qui tiennent une ressource et qui veulent capturer la ressource de l autre. possède requête Ressource A Inter-blocage Ressource B requête possède Auto-blocage : - Une tâche qui tente de capturer une ressource qu elle tient déjà. possède requête Ressource A Auto-blocage Défaut de synchronisation Défaut de programmation Cours # 2 ELE - Ordinateurs et programmation système 12 Cours # 2 ELE - Ordinateurs et programmation système 6
7 Introduction - synchronisation du noyau 1.2 Protection des ressources Quand le faire? Toujours prévoir la protection des ressources dés le début de la conception du code et non lorsqu il devient absolument nécessaire Quoi protéger? Besoin de protection Pas besoin de protection - Toute donnée qui est globale a probablement besoin de protection. - Toute donnée qui est partagée entre le contexte-processus et le contexte-interruption. - Toute donnée partagée entre des routines d interruptions. - La question à se poser est : Est-ce que la donnée peut être accédée par d autres? - Une donnée qui est locale à une tâche. - Toute donnée qui est créée dynamiquement par une tâche n existe que sur la pile de la tâche. Cours # 2 ELE - Ordinateurs et programmation système 1 Introduction - synchronisation du noyau 1.2 Protection des ressources 1.2. Catégorie de protection Préemption-sûr : Est protégé des accès concurrents avec la préemption du noyau. Interruption-sûr : Est protégé des accès concurrents de routines d interruptions. SMP-sûr : Est protégé des accès concurrents dans un système multiprocesseurs symétrique. Cours # 2 ELE - Ordinateurs et programmation système 1 Cours # 2 ELE - Ordinateurs et programmation système
8 2.1 Opérations atomiques Le noyau de Linux fournit 2 ensembles d opérations atomiques : Opérations entières atomiques : Type de donnée spéciale atomic_t - Ces variables ne peuvent être utilisées qu au travers d instructions spéciales. - Ces opérations sont exécutées sans aucune interruption. Création d une variable atomique : atomic_t v; atomic_t u = ATOMIC_INIT(); Variable pré-initialisée Utilisation d une variable atomique : équivalent à atomic_set (&v, ); v = ; atomic_add (2, &u); u = u + ; atomic_inc (&v); v = v + 1; int x = atomic_read(&v); x = v; Il y en a plusieurs autres atomic_dec_and_test (&u); u = u 1; et retourne Vrai si u = 0 après. Cours # 2 ELE - Ordinateurs et programmation système Opérations atomiques Opérations binaires atomiques : - Ces opérations peuvent agir sur les bits de n importe quel type de données. - Elles doivent recevoir un pointeur vers la variable à traiter. - Ces opérations sont exécutées sans aucune interruption. - Les opérations non-atomiques équivalentes portent le même nom mais sont précédées d un double sous-ligné. Opérations : Atomique set_bit (, &y); clear_bit (2, &y); change_bit (, &y); test_bit (21, &y); test_and_set_bit (15, &y); test_and_clear_bit (, &y); test_and_change_bit (, &y); Non-atomique set_bit (, &y); clear_bit (2, &y); change_bit (, &y); test_bit (21, &y); test_and_set_bit (15, &y); test_and_clear_bit (, &y); test_and_change_bit (, &y); Cours # 2 ELE - Ordinateurs et programmation système 16 Cours # 2 ELE - Ordinateurs et programmation système
9 2.2 Verrou tournant et sémaphore Les verrous tournants et les sémaphores sont les principaux mécanismes de protection (région critique) et de synchronisation du noyau. Verrou tournant (Spin lock) : - Seule une tâche à la fois peut posséder le verrou tournant. - Il sert à créer un morceau de code atomique. - Lorsque le verrou n est pas disponible, la tâche qui désire le capturer se place en attente active (ne dort pas) jusqu à ce qu il redevienne disponible. Tourne dans une boucle inutile et consomme du temps de processeur. Exemple de code d un verrou tournant : void Verrou_capture (int *verrou) { while (! test_and_set_bit (0, verrou)); } Opération atomique pour changer l état du verrou void Verrou_libère (int *verrou) { clear_bit (0, verrou); } Cours # 2 ELE - Ordinateurs et programmation système Verrou tournant et sémaphore Verrou tournant (Spin lock) : - À cause de l attente active, ce verrou ne doit pas être retenu trop longtemps. - Lorsque le verrou est capturé, la préemption du noyau est désactivée. Multiprocesseur Désactive la préemption seulement sur le processeur de la tâche qui possède le verrou. Monoprocesseur Désactive la préemption sur le processeur. - Mais les interruptions ne sont pas nécessairement désactivées. - Puisque qu il ne dort pas, il peut être utilisé dans les routines d interruptions. - ATTENTION : Ce verrou peut auto-bloquer!!! Exemple : spinlock_t my_lock = SPIN_LOCK_UNLOCKED; Déclaration Code atomique spin_lock (&my_lock); spin_unlock (&my_lock); Utilisation Région critique Cours # 2 ELE - Ordinateurs et programmation système 1 Cours # 2 ELE - Ordinateurs et programmation système 9
10 2.2 Verrou tournant et sémaphore Sémaphore : - Le sémaphore est un verrou dormant, s il n est pas disponible, la tâche qui le demande est placée dans une fil d attente (waiting queue). - À cause de ça, le sémaphore est utilisé seulement en contexte processus. - De plus, une tâche qui possède un verrou tournant ne peut pas tenter de capturer un sémaphore car elle pourrait dormir. - Contrairement aux verrous tournants, le sémaphore ne désactive pas la préemption du noyau et la tâche qui le tient peut être préemptée. Exemple de code d un sémaphore : void Capture_sem (atomic_t *sem) { if (atomic_add_negative (-1, sem)) { atomic_set (0, sem); sleep (current, sem); } } void Libère_sem (atomic_t *sem) { atomic_inc (sem); } La capture et la libération doit être faite de façon atomique. Cours # 2 ELE - Ordinateurs et programmation système Verrou tournant et sémaphore Sémaphore : - Dépendamment de son initialisation, un sémaphore peut être tenu par une seule ou par plusieurs tâches : Valeurs possibles 0 ou 1 Sémaphore binaire, aussi appelé Mutex. Sert habituellement pour créer un morceau de code atomique dans le but de protéger l accès à une ressource. 0 ou > 0 Sémaphore compteur. Sert habituellement pour la synchronisation ou pour protéger l accès à une ressource ayant plusieurs points d accès ou instances. - De façon générale, on peut faire l une de choses avec un sémaphore : Initialiser Capturer Libérer Appelé down() Appelé up() Cours # 2 ELE - Ordinateurs et programmation système 20 Cours # 2 ELE - Ordinateurs et programmation système 10
11 2.2 Verrou tournant et sémaphore Création d un sémaphore : manière statique manière dynamique static DECLARE_SEMAPHORE_GENERIC (my_sem, ); static DECLARE_MUTEX (my_sem); struct semaphore my_sem; sema_init (&my_sem, ); init_mutex (&my_sem); équivalent si égal à 1 équivalent si égal à 1 0 init_mutex_locked (&my_sem); Utilisation d un sémaphore : down (&my_sem); Capture ou dort en état TASK_UNINTERRUPTIBLE. down_interruptible (&my_sem); Capture ou dort en état TASK_INTERRUPTIBLE. down_trylock (&my_sem); Tente de capturer (si oui, retourne 0), mais ne dort pas. up (&my_sem); Libère le sémaphore ou le Mutex. Cours # 2 ELE - Ordinateurs et programmation système Variable de terminaison - Similaire aux sémaphores, elle permet à une tâche de signaler qu elle à fini à une autre tâche qui attends. - Utilisé principalement pour la synchronisation, c est-à-dire pour permettre à une tâche de dire à une autre quand faire son travail. Création d une variable de terminaison : manière statique manière dynamique DECLARE_COMPLETION (ma_var); struct completion ma_var; init_completion (&ma_var); Utilisation d un sémaphore : C est un mécanisme simple et léger de synchronisation de deux tâches wait_for_completion (&ma_var); Attend le signal de fin d utilisation. complete (&ma_var); Envoi le signal de fin d utilisation. Cours # 2 ELE - Ordinateurs et programmation système 22 Cours # 2 ELE - Ordinateurs et programmation système 11
12 2. Désactivation de la préemption du noyau - Comme il a été mentionné, lorsqu un verrou tournant est capturé, la préemption du noyau est désactivée. - Mais il arrive qu il soit nécessaire de désactiver la préemption du noyau sans avoir recours à un verrou tournant. - Par exemple, pour créer un morceau de code atomique de très courte durée. - La désactivation du noyau est récursive, c est-à-dire qu elle peut être faite plusieurs fois de suite et elle devra être réactivée autant fois pour être de nouveau active. Utilisation de la désactivation de la préemption du noyau : preempt_disable ( ); preempt_enable ( ); preempt_count ( ); Désactive la préemption du noyau et compte. Décompte et réactive la préemption du noyau lorsque le compte est à zéro. Retourne le compte actuel. Cours # 2 ELE - Ordinateurs et programmation système Séquence d exécution et barrières Séquence d exécution : - Pour des raisons d optimisation, il arrive que les compilateurs changent l ordre d une séquence de lecture et d écriture de données au moment de la compilation. - Aussi, certains processeurs effectuent des écritures out-of-order automatiquement et qui change l ordre de séquences d écritures. - Par exemple, la séquence suivante : a = 1; est exécutée b = 2; b = 2; dans l ordre a = 1; - Du autre côté, il est parfois nécessaire de s assurer que la séquence d exécution est respectée, surtout lors d accès au matériel. - Pour forcer le respect de l ordre d une séquence, Linux fournit la notion de barrière et les fonctions qui vont avec. Cours # 2 ELE - Ordinateurs et programmation système 2 Cours # 2 ELE - Ordinateurs et programmation système 12
13 2.5 Séquence d exécution et barrières Barrière : - La barrière fournit un mécanisme de sérialisation, c est-à-dire d empêcher qu un réarrangement de l exécution se fasse au travers de la barrière. - Les lectures ou écritures de données se trouvant avant la barrière seront complétées obligatoirement avant. Tandis que les lectures ou écritures se trouvant après la barrière ne pourront pas être effectuées avant. Utilisation de barrières : rmb ( ); umb ( ); mb ( ); Barrière de lecture. Barrière d écriture. Barrière de lecture et d écriture. read_barrier_depends ( ); Cas particulier d une barrière d écriture où seuls les écritures dépendantes de part et d autre de la barrière sont affectées. Cours # 2 ELE - Ordinateurs et programmation système Séquence d exécution et barrières Exemple de Barrière : Soit 2 tâches parfaitement synchronisées qui exécutent le code suivant : Sans la barrière Avec la barrière A = ; B = ; B A Mémoire A B 2 2 CPU-B 1 A 1 C = B; D = A; D B C A = ; mb(); B = ; A B Mémoire A 1 1 B CPU-B 2 B 2 C = B; rmb(); D = A; C A D Et cela peut arriver aussi avec des tâches sur un même processeur Cours # 2 ELE - Ordinateurs et programmation système 26 Cours # 2 ELE - Ordinateurs et programmation système 1
14 2.6 Verrou tournant et sémaphore «lecteur / écrivain» Principe du «lecteur / écrivain» : - Il n est pas nécessaire de protéger l accès à une donnée lorsqu il s agit uniquement de la lire, du moment qu elle ne change pas en cours de route. - Donc on peut permettre autant de «lecteurs» simultanés que l on veut. - Par contre, dés qu un «écrivain» accède à la donnée pour la changer, alors il doit être seul, sinon il y a un risque de collision. - Donc, les verrous «lecteur / écrivain» permettent à tous les lecteurs de capturer le verrou, du moment qu il n est pas en la possession d un écrivain. - Si un écrivain a capturé le verrou, alors aucun lecteur ne peut le prendre. Verrou tournant «lecteur / écrivain» : rwlock_t my_rwlock = RW_LOCK_UNLOCKED; read_lock (&my_rwlock); Région critique : Lecteur read_unlock (&my_rwlock); Déclaration write_lock (&my_rwlock); Région critique : Écrivain write_unlock (&my_rwlock); Cours # 2 ELE - Ordinateurs et programmation système Verrou tournant et sémaphore «lecteur / écrivain» Sémaphore «lecteur / écrivain» : - Tous les sémaphores «lecteur / écrivain» sont des Mutex (0, 1). - Les sémaphores «lecteur / écrivain» placent les tâches en attente dans l état TASK_UNINTERRUPTIBLE. Déclaration manière static DECLARE_RWSEM (rw_sem); statique Utilisation manière dynamique struct rw_semaphore rw_sem; init_rwsem (&rw_sem); down_read (&rw_sem); Région critique : Lecteur down_write (& rw_sem); Région critique : Écrivain up_read (&rw_sem); up_write (& rw_sem); Aussi down_read_trylock (&rw_sem); down_write_trylock (& rw_sem); downgrade_writer (&rw_sem); Cours # 2 ELE - Ordinateurs et programmation système 2 Cours # 2 ELE - Ordinateurs et programmation système 1
15 2. Verrous séquentiels - Le but du verrou séquentiel est sensiblement le même que celui des verrous «lecteur / écrivain». - C est un mécanisme simple qui permet à tous les lecteurs d accéder à la donnée protégée, même si un écrivain est en action sur la donnée. - Par contre, à la fin de la lecture, le lecteur doit vérifier si la donnée a changée en cours de route et si oui, il reprend sa lecture. - L écrivain doit capturer le verrou pour accéder à la donnée. Ce faisant, il incrémente un «numéro de séquence» (devient impair). - Lorsque l écrivain libère le verrou, il incrémente de nouveau le «numéro de séquence» (devient pair). - Avant d accéder à la donnée, le lecteur prend une copie de ce «numéro de séquence». Et après avoir lut la donnée, il compare sa copie à la valeur actuelle du «numéro de séquence». S il a changé, alors un écrivain a changé la donnée. - De plus, si le «numéro de séquence» est impair, un écrivain est en train de changer la donnée, sinon il a terminé. Cours # 2 ELE - Ordinateurs et programmation système Verrous séquentiels Déclaration Utilisation Côté lecteur : Boucle tant qu il change. Côté écrivain : seqlock_t mon_seq = SEQLOCK_UNLOCKED; unsigned long seq; do { seq = read_seqbegin (&mon_seq); Région critique : Lecteur } while (read_seqretry(&mon_seq, seq)); write_seqlock (&mon_seq); Région critique : Écrivain write_sequnlock (&mon_seq); Nécessaire pour recevoir la copie du numéro de séquence (unsigned long). Prend la copie du numéro de séquence. Compare la copie du numéro de séquence. Capture le verrou et incrémente le numéro de séquence. Libère le verrou et incrémente le numéro de séquence. Cours # 2 ELE - Ordinateurs et programmation système 0 Cours # 2 ELE - Ordinateurs et programmation système 15
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
Plus en détailINTRODUCTION 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
Plus en détailProblè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
Plus en détail4. Outils pour la synchronisation F. Boyer, Laboratoire Lig Fabienne.Boyer@imag.fr
4. Outils pour la synchronisation F. Boyer, Laboratoire Lig Fabienne.Boyer@imag.fr Le problème Insuffisance des solutions de base (verrous) Les solutions de plus haut niveau Les Sémaphores Les Moniteurs
Plus en détailExé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
Plus en détail1 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
Plus en détailTemps Réel. Jérôme Pouiller <j.pouiller@sysmic.org> Septembre 2011
Temps Réel Jérôme Pouiller Septembre 2011 Sommaire Problèmatique Le monotâche Le multitâches L ordonnanement Le partage de ressources Problèmatiques des OS temps réels J. Pouiller
Plus en détailIntroduction 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/ Laure.Gonnord@univ-lyon1.fr Master CCI -
Plus en détailREALISATION 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
Plus en détailTemps Réel. Jérôme Pouiller <j.pouiller@sysmic.org> 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
Plus en détailIntroduction à 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
Plus en détailÉ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
Plus en détailCours 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
Plus en détailUn 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
Plus en détailIntroduction : 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
Plus en détailLes 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
Plus en détailJ2SE 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
Plus en détail03/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
Plus en détail4. Outils pour la synchronisation F. Boyer, Laboratoire Sardes Fabienne.Boyer@imag.fr
4. Outils pour la synchronisation F. Boyer, Laboratoire Sardes Fabienne.Boyer@imag.fr Le problème Insuffisance des solutions de base (verrous) Les solutions de plus haut niveau Les Sémaphores Les Moniteurs
Plus en détailInfo0604 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
Plus en détailINTRODUCTION À 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
Plus en détailCours 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 m.daoudi@fso.ump.ma Février
Plus en détailChapitre 2. Les processus. 2.1 Introduction. 2.2 les différents états d un processus
Chapitre 2 Les processus 2.1 Introduction Le processus est un concept clé dans un système d exploitation. Un processus est un programme en cours d exécution. C est-à-dire, un programme à l état actif.
Plus en détailINITIATION AU LANGAGE C SUR PIC DE MICROSHIP
COURS PROGRAMMATION INITIATION AU LANGAGE C SUR MICROCONTROLEUR PIC page 1 / 7 INITIATION AU LANGAGE C SUR PIC DE MICROSHIP I. Historique du langage C 1972 : naissance du C dans les laboratoires BELL par
Plus en détailLOG4430 : 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,
Plus en détailIntroduction à 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
Plus en détailSynchro 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
Plus en détailGPA770 Microélectronique appliquée Exercices série A
GPA770 Microélectronique appliquée Exercices série A 1. Effectuez les calculs suivants sur des nombres binaires en complément à avec une représentation de 8 bits. Est-ce qu il y a débordement en complément
Plus en détailExclusion Mutuelle. Arnaud Labourel Courriel : arnaud.labourel@lif.univ-mrs.fr. Université de Provence. 9 février 2011
Arnaud Labourel Courriel : arnaud.labourel@lif.univ-mrs.fr Université de Provence 9 février 2011 Arnaud Labourel (Université de Provence) Exclusion Mutuelle 9 février 2011 1 / 53 Contexte Epistémologique
Plus en détailBases 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
Plus en détailIFT2245 - 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
Plus en détailCours A7 : Temps Réel
Cours A7 : Temps Réel Pierre.Paradinas / @ / cnam.fr Cnam/Cedric Systèmes Enfouis et Embarqués (SEE) Motivations Du jour : les mécanismes multitâches, la gestion des priorités, l ordonnancement, la gestion
Plus en détailNotion 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
Plus en détailAnalyse de sécurité de logiciels système par typage statique
Contexte Modélisation Expérimentation Conclusion Analyse de sécurité de logiciels système par typage statique Application au noyau Linux Étienne Millon UPMC/LIP6 Airbus Group Innovations Sous la direction
Plus en détailIV- Comment fonctionne un ordinateur?
1 IV- Comment fonctionne un ordinateur? L ordinateur est une alliance du hardware (le matériel) et du software (les logiciels). Jusqu à présent, nous avons surtout vu l aspect «matériel», avec les interactions
Plus en détailEPREUVE 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
Plus en détailACTIVITÉ DE PROGRAMMATION
ACTIVITÉ DE PROGRAMMATION The purpose of the Implementation Process is to realize a specified system element. ISO/IEC 12207 Sébastien Adam Une introduction 2 Introduction Ø Contenu Utilité de l ordinateur,
Plus en détailChapitre 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
Plus en détailProcessus! 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
Plus en détailM2-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 :
Plus en détailInfo0101 Intro. à l'algorithmique et à la programmation. Cours 3. Le langage Java
Info0101 Intro. à l'algorithmique et à la programmation Cours 3 Le langage Java Pierre Delisle, Cyril Rabat et Christophe Jaillet Université de Reims Champagne-Ardenne Département de Mathématiques et Informatique
Plus en détailAlgorithmique 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
Plus en détailInitiation au HPC - Généralités
Initiation au HPC - Généralités Éric Ramat et Julien Dehos Université du Littoral Côte d Opale M2 Informatique 2 septembre 2015 Éric Ramat et Julien Dehos Initiation au HPC - Généralités 1/49 Plan du cours
Plus en détailMesure de performances. [Architecture des ordinateurs, Hennessy & Patterson, 1996]
Mesure de performances [Architecture des ordinateurs, Hennessy & Patterson, 1996] Croissance des performances des microprocesseurs Avant le milieu des années 80, le gain dépendait de la technologie. Après,
Plus en détailConventions d écriture et outils de mise au point
Logiciel de base Première année par alternance Responsable : Christophe Rippert Christophe.Rippert@Grenoble-INP.fr Introduction Conventions d écriture et outils de mise au point On va utiliser dans cette
Plus en détailMétriques de performance pour les algorithmes et programmes parallèles
Métriques de performance pour les algorithmes et programmes parallèles 11 18 nov. 2002 Cette section est basée tout d abord sur la référence suivante (manuel suggéré mais non obligatoire) : R. Miller and
Plus en détailInitiation. àl algorithmique et à la programmation. en C
Initiation àl algorithmique et à la programmation en C Initiation àl algorithmique et à la programmation en C Cours avec 129 exercices corrigés Illustration de couverture : alwyncooper - istock.com Dunod,
Plus en détailSystè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
Plus en détailProgrammation C. Apprendre à développer des programmes simples dans le langage C
Programmation C Apprendre à développer des programmes simples dans le langage C Notes de cours sont disponibles sur http://astro.u-strasbg.fr/scyon/stusm (attention les majuscules sont importantes) Modalités
Plus en détailTp 1 correction. Structures de données (IF2)
Tp 1 correction Structures de données (IF2) Remarque générale : compilez et exécutez le code au-fur-et-à mesure de son écriture. Il est plus facile de corriger une petite portion de code délimitée que
Plus en détailProjet gestion d'objets dupliqués
Projet gestion d'objets dupliqués Daniel Hagimont Daniel.Hagimont@enseeiht.fr 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
Plus en détailConception des systèmes répartis
Conception des systèmes répartis Principes et concepts Gérard Padiou Département Informatique et Mathématiques appliquées ENSEEIHT Octobre 2012 Gérard Padiou Conception des systèmes répartis 1 / 37 plan
Plus en détailDAns un système multi-utilisateurs à temps partagé, plusieurs processus
Chapitre 8 Ordonnancement des processus Dns un système multi-utilisateurs à temps partagé, plusieurs processus peuvent être présents en mémoire centrale en attente d exécution. Si plusieurs processus sont
Plus en détailIntroduction à la programmation orientée objet, illustrée par le langage C++ Patrick Cégielski cegielski@u-pec.fr
Introduction à la programmation orientée objet, illustrée par le langage C++ Patrick Cégielski cegielski@u-pec.fr Mars 2002 Pour Irène et Marie Legal Notice Copyright c 2002 Patrick Cégielski Université
Plus en détailNFP 121. Java et les Threads. Présentation : Thierry Escalarasse Mai 2007
NFP 121 Java et les Threads Présentation : Thierry Escalarasse Mai 2007 Plan du cour Présentation de la notion de Threads La classe Thread L interface Runnable Les états d un thread La Synchronisation
Plus en détailINITIATION 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
Plus en détail1. 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
Plus en détailLicence 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
Plus en détailSupport de cours système d exploitation
Support de cours système d exploitation J. Gispert, J. Guizol, J.L. Massat Département d informatique Faculté de Luminy 163, Avenue de Luminy, Case 901, 13288 Marseille, cedex 9 23 février 2012 Chapitre
Plus en détailAtelier C TIA Portal CTIA06 : programmation des automates S7-300 Blocs d organisation
Atelier C TIA Portal CTIA06 : programmation des automates S7-300 Blocs d organisation CTIA06 Page 1 1. Types de blocs de programme L automate met à disposition différents types de blocs qui contiennent
Plus en détailProgrammation 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
Plus en détailOn 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
Plus en détailOrdinateurs, Structure et Applications
Ordinateurs, Structure et Applications Cours 10, Les interruptions Etienne Tremblay Université Laval, Hiver 2012 Cours 10, p.1 Les interruptions du 8086 Une interruption interrompt l exécution séquentielle
Plus en détailIN 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
Plus en détailSystèmes et exécutifs temps-réel
Systèmes et exécutifs temps-réel Licence professionnelle «Systèmes embarqués dans l automobile» Isabelle PUAUT (Cours + TD) Jean-François DEVERGE et Christophe Pais (TP) 1 Applications temps-réel Systèmes
Plus en détail<Insert Picture Here> Solaris pour la base de donnés Oracle
Solaris pour la base de donnés Oracle Alain Chéreau Oracle Solution Center Agenda Compilateurs Mémoire pour la SGA Parallélisme RAC Flash Cache Compilateurs
Plus en détailAnne Tasso. Java. Le livre de. premier langage. 10 e édition. Avec 109 exercices corrigés. Groupe Eyrolles, 2000-2015, ISBN : 978-2-212-14154-2
Anne Tasso Java Le livre de premier langage 10 e édition Avec 109 exercices corrigés Groupe Eyrolles, 2000-2015, ISBN : 978-2-212-14154-2 Table des matières Avant-propos Organisation de l ouvrage..............................
Plus en détailDE L ALGORITHME AU PROGRAMME INTRO AU LANGAGE C 51
DE L ALGORITHME AU PROGRAMME INTRO AU LANGAGE C 51 PLAN DU COURS Introduction au langage C Notions de compilation Variables, types, constantes, tableaux, opérateurs Entrées sorties de base Structures de
Plus en détailOrdonnancement temps réel
Ordonnancement temps réel Laurent.Pautet@enst.fr 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
Plus en détailThreads. 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
Plus en détailMéthodes de programmation systèmes UE n NSY103. Notes de cours. Nombre d'heures : 55h (~18 + 1 cours de 3 heures)
Méthodes de programmation systèmes UE n NSY103 Notes de cours Code de l UE : NSY103 Titre de la formation : Méthodes de programmation systèmes Ouvert : Ouvert Type de diplôme : Unité de valeur CNAM. Nombre
Plus en détailVIII- Circuits séquentiels. Mémoires
1 VIII- Circuits séquentiels. Mémoires Maintenant le temps va intervenir. Nous avions déjà indiqué que la traversée d une porte ne se faisait pas instantanément et qu il fallait en tenir compte, notamment
Plus en détailTravaux pratiques. Compression en codage de Huffman. 1.3. Organisation d un projet de programmation
Université de Savoie Module ETRS711 Travaux pratiques Compression en codage de Huffman 1. Organisation du projet 1.1. Objectifs Le but de ce projet est d'écrire un programme permettant de compresser des
Plus en détailDans le chapitre 1, nous associions aux fichiers ouverts des descripteurs de fichiers par lesquels nous accédions aux fichiers.
I Présentation : Dans le chapitre 1, nous avons vu comment utiliser les appels-systèmes de bas niveau pour créer et accéder à des fichiers sur le disque. Nous avons notamment mis en évidence leur dépouillement
Plus en détailLes Threads. Sommaire. 1 Les Threads
1 Les Threads Les Threads Sommaire Les Threads... 1 1 Introduction... 2 2 Les Threads : Notions de base... 3 2.1 Créer un Thread avec une méthode non paramétrée... 5 2.2 Les threads à méthode paramétrée...
Plus en détailIntroduction aux systèmes temps réel. Iulian Ober IRIT ober@iut-blagnac.fr
Introduction aux systèmes temps réel Iulian Ober IRIT ober@iut-blagnac.fr Sommaire Généralités Caractéristiques récurrentes des STR Types de problèmes soulevées Programmation des STR Prog. concurrente
Plus en détailCours 1 : Qu est-ce que la programmation?
1/65 Introduction à la programmation Cours 1 : Qu est-ce que la programmation? Yann Régis-Gianas yrg@pps.univ-paris-diderot.fr Université Paris Diderot Paris 7 2/65 1. Sortez un appareil qui peut se rendre
Plus en détailUE C avancé cours 1: introduction et révisions
Introduction Types Structures de contrôle Exemple UE C avancé cours 1: introduction et révisions Jean-Lou Desbarbieux et Stéphane Doncieux UMPC 2004/2005 Introduction Types Structures de contrôle Exemple
Plus en détailLes structures. Chapitre 3
Chapitre 3 Les structures Nous continuons notre étude des structures de données qui sont prédéfinies dans la plupart des langages informatiques. La structure de tableau permet de regrouper un certain nombre
Plus en détailCorrigés des premiers exercices sur les classes
Corrigés des premiers exercices sur les classes Exercice 2.1.1 utilisation d une classe Voici le texte d une classe représentant de façon sommaire un compte bancaire et les opérations bancaires courantes.
Plus en détailGestion 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
Plus en détailArgument-fetching dataflow machine de G.R. Gao et J.B. Dennis (McGill, 1988) = machine dataflow sans flux de données
EARTH et Threaded-C: Éléments clés du manuel de références de Threaded-C Bref historique de EARTH et Threaded-C Ancêtres de l architecture EARTH: Slide 1 Machine à flux de données statique de J.B. Dennis
Plus en détailMODULE I1. Plan. Introduction. Introduction. Historique. Historique avant 1969. R&T 1ère année. Sylvain MERCHEZ
MODULE I1 Plan Chapitre 1 Qu'est ce qu'un S.E? Introduction Historique Présentation d'un S.E Les principaux S.E R&T 1ère année Votre environnement Sylvain MERCHEZ Introduction Introduction Rôles et fonctions
Plus en détailPré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)
Plus en détailTD2/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!
Plus en détailProgrammation impérative
Programmation impérative Cours 4 : Manipulation des fichiers en C Catalin Dima Organisation des fichiers Qqs caractéristiques des fichiers : Nom (+ extension). Chemin d accès absolu = suite des noms des
Plus en détailEclipse atelier Java
Eclipse atelier Java Table des matières 1. Introduction...2 2. Télécharger eclipse...3 3. Installer eclipse...3 4. Premier lancement d eclipse...3 5. Configurer eclipse pour faire du Java...5 6. Développer
Plus en détailPartie 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
Plus en détailCours de C++ François Laroussinie. 2 novembre 2005. Dept. d Informatique, ENS de Cachan
Cours de C++ François Laroussinie Dept. d Informatique, ENS de Cachan 2 novembre 2005 Première partie I Introduction Introduction Introduction Algorithme et programmation Algorithme: méthode pour résoudre
Plus en détailQu'est-ce qu'un processus: Définitions
Version septembre 2013 N 187 Qu'est-ce qu'un processus: Définitions Instruction = indécomposable et indivisible Processeur =... Processus = suite temporelle d'exécutions d'instructions Processus = exécution
Plus en détailPremiers 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.
Plus en détailARDUINO 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
Plus en détailProgrammer en JAVA. par Tama (tama@via.ecp.fr( tama@via.ecp.fr)
Programmer en JAVA par Tama (tama@via.ecp.fr( tama@via.ecp.fr) 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
Plus en détailLe 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
Plus en détailProgramme 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
Plus en détailExceptions. 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
Plus en détailLa programmation des PIC en C. Les fonctions, les interruptions.
La programmation des PIC en C Les fonctions, les interruptions. Réalisation : HOLLARD Hervé. http://electronique-facile.com Date : 26 août 2004 Révision : 1.2 Sommaire Sommaire... 2 Introduction... 3 Structure
Plus en détailContraintes, particularités. 1. Généralités... 2. 2. Gestion de la mémoire... 2. a. Type des variables et constantes... 2
C Embarque Contraintes, particularités 1. Généralités... 2 2. Gestion de la mémoire... 2 a. Type des variables et constantes.... 2 b. Variables locales ou globales... 3 3. Interruptions... 5 4. Imposer
Plus en détailCours de Programmation Impérative: Zones de mémoires et pointeurs
Cours de Programmation Impérative: Zones de mémoires et pointeurs Julien David A101 - david@lipn.univ-paris13.fr Julien David (A101 - david@lipn.univ-paris13.fr) 1 / 1 Z`o n`e s `d`e m`é m`o i r`e Julien
Plus en détail