TRAVAUX PRATIQUES Programmation Système Langage C / Système UNIX. 2 e année Génie Informatique

Dimension: px
Commencer à balayer dès la page:

Download "TRAVAUX PRATIQUES Programmation Système Langage C / Système UNIX. 2 e année Génie Informatique"

Transcription

1 Communications entre Processus Communication par tubes. TRAVAUX PRATIQUES Programmation Système Langage C / Système UNIX. 2 e année Génie Informatique Exemple 1: On a deux processus Père/Fils. Le père envoi au fils un message dans un tube. Message envoyé en bloc et lu caractère par caractère puis imprimé. #include <unistd.h> char message[25] = "Cela provient d'un tube"; /* * communication PERE --> FILS par pipe int p[2]; int pipe(int[2]); if (pipe(p) == -1) fprintf(stderr, "erreur ouverture pipe\n"); exit(1); if (fork() == 0) /* fils char c; while (read(p[0], &c, 1)!= 0) printf("%c", c); else /* suite pere write(p[1], message, 24); Remarquer l'arrêt de read() sur valeur retour nulle. (Réalisé par dans le processus père). Exercice: Faire un programme où ce sont deux fils qui communiquent, l'un écrivain et l'autre lecteur. Exemple 2: Considérons maintenant deux écrivains et un lecteur sur le même tube. Deux fils écrivent respectivement les séquences "ABC...Z" et "abc...z" par blocs de trois caractères, et un troisième fils lit dans le tube par blocs de 4 caractères. #include <unistd.h> /* Cummunication par pipe * FILS1 et FILS2 Ecrivains Najib TOUNSI 1

2 * FILS3 lecteur, meme pipe void f1(), f2(), f3(); /* les 3 fils void (*tab_fonct[3]) () = f1, f2, f3; int p[2]; char seq1[27] = "ABCDEFGHIJKILMOPQRSTUVWXYZ"; /* ecrite par FILS1 char seq2[27] = "abcdefghijklmnopqrstuvwxyz"; /* ecrite par FILS2 int i; int pipe(); if (pipe(p) == -1) fprintf(stderr, "erreur ouverture pipe\n"); exit(1); for (i = 0; i < 3; i++) switch (fork()) case 0: (*tab_fonct[i]) (); default:; void f1() int i; for (i = 0; i < 26; i += 3) write(p[1], &seq1[i], 3); sleep(3); void f2() int i; for (i = 0; i < 26; i += 3) write(p[1], &seq2[i], 3); sleep(4); void f3() char s[5]; int nb_lu; while ((nb_lu = read(p[0], s, 4)) > 0) printf("%s", s); printf("\n"); Les appels sleep() entre chaque écriture des écrivains, sont là pour simuler d'autres traitements des processus. Najib TOUNSI 2

3 Exemple de Programme Communications entre Processus. Communication par tubes nommés (fifos). Voici deux programmes, serveur.c et client.c, qui communiquent par deux tubes nommés cli2serv et serv2cli. Deux Processus Communicants Par Tubes nommés Le programme client.c envoie une requête de type a + b, dans le tube cli2serv, et le programme serveur.c lui retourne la réponse dans le tube serv2cli. C'est le programme serveur.c qui crée les tubes (désignés par les variables QUESTION et REPONSE) et qui les supprime en fin d'exécution. Il doit donc être lancé avant le programme client qui suppose les tubes existants. Les deux programmes se synchronisent sur l'ouverture des tubes qui doit se faire dans le même ordre. L'arrêt de la communication se fait quand le programme client envoi le message bye; le serveur répond alors par ciao. programme serveur.c % cat serveur.c /* Serveur: retourne resultat (requete a+b) * Cree les fifos cli2serv et serv2cli * LANCER LE SERVEUR D'ABORD (car il ecrase fifos) #include <sys/types.h> #include <fcntl.h> #include <string.h> #define QUESTION "cli2serv" #define REPONSE "serv2cli" void trait(); /* traitement du serveur int fdq, fdr; unlink(question); unlink(reponse); /* Creation fifos if (mkfifo(question, 0644) == -1 mkfifo(reponse, 0644) == -1) perror("impossible creer fifos"); /* Attente des ouvertures Clients Najib TOUNSI 3

4 fdq = open(question, O_RDONLY); fdr = open(reponse, O_WRONLY); trait(fdr, fdq); close(fdq); close(fdr); unlink(question); unlink(reponse); void trait(fdr, fdq) int fdr, fdq; /* fdr et fdq descripteurs reponse/question int opd1, opd2, res; char opr; char quest[11]; char rep[11]; /* traitement serveur * envoi reponse a question * a + b venant de client. * arret question = "Ciao" while (1) read(fdq, quest, 10); sscanf(quest, "%d%1s%d", &opd1, &opr, &opd2); if (strcmp(quest, "Ciao") == 0) strcpy(rep, "Bye"); write(fdr, rep, 10); break; res = opd1 + opd2; sprintf(rep, "%d", res); write(fdr, rep, 10); programme client.c % cat client.c /* Client: envoie expressions * Les fifos sont supposes crees * par le serveur et sont cli2serv * et serv2cli #include <sys/types.h> #include <fcntl.h> #include <string.h> #define QUESTION "cli2serv" #define REPONSE "serv2cli" void trait(); /* traitement client int fdq, fdr; fdq = open(question, O_WRONLY); if (fdq == -1) fprintf(stderr, "Impossible ouvrire fifo %s\n", QUESTION); fprintf(stderr, "Lancer serveur d\'abord?\n"); Najib TOUNSI 4

5 fdr = open(reponse, O_RDONLY); if (fdr == -1) fprintf(stderr, "Impossible ouvrire fifo %s\n", REPONSE); fprintf(stderr, "Lancer serveur d\'abord?\n"); trait(fdr, fdq); close(fdq); close(fdr); void trait(fdr, fdq) int fdr, fdq; /* fdr et fdq descripteurs reponse/question char rep[11]; char quest[10]; /* traitement client * lecture expression a op b * dans stdin et ecriture reponse * dans stdout. Arret rep = "Bye" while (1) if (gets(quest) == NULL) write(fdq, quest, 10); printf("client -> %s \n", quest); read(fdr, rep, 10); printf("serveur -> %s \n", rep); if (strcmp(rep, "Bye") == 0) break; Script d'exécution % ls cli_serv serv_cli cli_serv not found serv_cli not found % client Impossible ouvrire fifo cli_serv Lancer serveur d'abord? % serveur & [1] % client 2 +4 Client -> 2 +4 Serveur -> Client -> Serveur -> 10 Ciao Client -> Ciao Serveur -> Bye [1] + Done serveur PS: Bravo et félicitations pour votre patience... Najib TOUNSI 5

6 Projet Mini Shell Najib Tounsi Squelette initial - Faire le programme suivant: C]$ cat minishell2.c #include<stdio.h> #include<string.h> #define L 80 #define W 20 char ligne[l]; /* Ligne commande char mot[w][l]; /* Les mots de la ligne commande void LireLigneCom(); void TraitLigneCom(); int ExecuterCom(); int pid, i, j, s; LireLigneCom(); TraitLigneCom(); while (strcmp(mot[0], "logout")!= 0) s = ExecuterCom(); printf("%d\n", s); LireLigneCom(); TraitLigneCom(); void LireLigneCom() char prompt[20] = "MiniShell OK>"; printf("%s", prompt); fgets(ligne, L + 1, stdin); /* gets() deconseillee /* On lit une ligne commande de 80 caracteres void TraitLigneCom() /* Selectionne les mots de la ligne commande et les place dans la tableau mot[] sscanf(ligne, "%s", mot[0]); /* Test: on commence par le 1er mot qui est la commande int ExecuterCom() /* Sera developpe' dans le cadre de ce TP int pid, status; if (strlen(mot[0]) == 0) /* pas de commande return 0; /* On lance un fils qui va executer la commande switch (pid = fork()) case -1: return -1; /* pas de fork case 0: if (execlp(mot[0], mot[0], mot[1], NULL) == -1) Najib TOUNSI 6

7 /* exec echoue exit(2) ; default: /* le minishell attend la fin de la commande if (wait(&status)==-1) return -1 ; return status/256; /* NB. le NULL dans execlp devra être remplacé par les autres mots de la ligne commande 1) Tester le programme sur des fichiers exécutables de votre choix. 2) Développer ce programme pour: - Tenir compte des paramètres de la commande à exécuter (Remplir le tableau mot[][]) - Lancement de la commande en background (utiliser waitpid() ) - Tenir compte d'un tube entre deux commandes sans paramètres NB. Faire man execl, man wait, etc... pour en savoir plus. Najib TOUNSI 7

Traducteur mot à mot

Traducteur mot à mot Traducteur mot à mot CORRECTION Ce document, ainsi que le programme C et un exemple de programme trad-fr-us, peut être trouvé en ligne à l'addresse suivante : http ://www.lifl.fr/hauspie/hauspie/teaching.

Plus en détail

Programmation système de commandes en C

Programmation système de commandes en C Programmation système de commandes en C Cours de Programmation système Tuyêt Trâm DANG NGOC Université de Cergy-Pontoise 2012 2013 Tuyêt Trâm DANG NGOC Programmation système de commandes

Plus en détail

Cours 6 : Tubes anonymes et nommés

Cours 6 : Tubes anonymes et nommés Cours 6 : Tubes anonymes et nommés Mécanisme de communications du système de fichiers I-node associé. Type de fichier: S_IFIFO. Accès au travers des primitives read et write. Les tubes sont unidirectionnels

Plus en détail

Examen. Les processus. Examen : systèmes d exploitation L3, parcours informatique, 2004-2005

Examen. Les processus. Examen : systèmes d exploitation L3, parcours informatique, 2004-2005 Mercredi 5 janvier 2005 Durée : 3 heures Documents autorisés Examen : systèmes d exploitation L3, parcours informatique, 2004-2005 Corrigé préliminaire et partiel. Examen Les valeurs de retour des primitives

Plus en détail

Département de génie informatique et génie logiciel

Département de génie informatique et génie logiciel INF2610 Chapitre 2 : Processus Département de génie informatique et génie logiciel Hiver 2014 Chapitre 2 - Processus Qu est ce qu un processus? États d un processus Hiérarchie des processus Processus UNIX-Linux

Plus en détail

Création et synchronisation de processus. Communications par signaux, par tubes.

Création et synchronisation de processus. Communications par signaux, par tubes. Création et synchronisation de processus. Communications par signaux, par tubes. Un processus est un ensemble d'octets (en langage machine) en cours d'exécution, en d'autres termes, c'est l'exécution d'un

Plus en détail

Cours de Système : Les processus

Cours de Système : Les processus Cours de Système : Les processus Bertrand Le cun et Emmanuel Hyon bertrand.le cun{at}u-paris10.fr et Emmanuel.Hyon{at}u-paris10.fr Université Paris Ouest Nanterre 29 novembre 2011 B.L.C. et E.H. (UPO)

Plus en détail

3IS - Système d'exploitation linux - Programmation système

3IS - Système d'exploitation linux - Programmation système 3IS - Système d'exploitation linux - Programmation système 2010 David Picard Contributions de : Arnaud Revel, Mickaël Maillard picard@ensea.fr Environnement Les programmes peuvent être exécutés dans des

Plus en détail

UNIX COMMUNICATION INTERNE ENTRE PROCESSUS. C. Crochepeyre Cnam - Diapason Unix: communications internes 1

UNIX COMMUNICATION INTERNE ENTRE PROCESSUS. C. Crochepeyre Cnam - Diapason Unix: communications internes 1 UNIX COMMUNICATION INTERNE ENTRE PROCESSUS C. Crochepeyre Cnam - Diapason Unix: communications internes 1 1. GÉNÉRALITÉS Communications internes: entre processus sur une même machine: exec() fichiers moyens

Plus en détail

Sujet Projets 2 nd Semestre

Sujet Projets 2 nd Semestre Sujet Projets 2 nd Semestre Seuls les appels systèmes vus en cours sont autorisés. L usage d autres fonctions doit impérativement être validé par l enseignant. La date d ouverture pour l assignation de

Plus en détail

Cours Programmation Système

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 m.daoudi@fso.ump.ma Février

Plus en détail

LEs processus coopèrent souvent pour traiter un même problème. Ces

LEs processus coopèrent souvent pour traiter un même problème. Ces Chapitre 5 Communication interprocessus LEs processus coopèrent souvent pour traiter un même problème. Ces processus s exécutent en parallèle sur un même ordinateur (monoprocesseur ou multiprocesseurs)

Plus en détail

Processus. Identité d'un processus

Processus. Identité d'un processus Processus Processus: entité active du système 1 correspond à l'exécution d'un programme binaire 1 identifié de façon unique par son numéro : pid 1 possède 3 segments : 2 code, données et pile 1 Exécuté

Plus en détail

GESTION DES FICHIERS C/UNIX

GESTION DES FICHIERS C/UNIX Licence IG Page 1 sur 6 GESTION DES FICHIERS C/UNIX Introduction Deux modes d appel - Par la bibliothèque standard C (appel de haut niveau) - Par appels système (bas niveau) Nécessite les includes suivant

Plus en détail

1.Introduction à la gestion des processus et aux tubes de communication

1.Introduction à la gestion des processus et aux tubes de communication Travaux pratique d'informatique Temps Réel,, TP 1 1 1.Introduction à la gestion des processus et aux tubes de communication 1.1.Objectifs La séance vise à familiariser l'étudiant avec les concepts de processus

Plus en détail

Tubes et Tubes Nommés

Tubes et Tubes Nommés Chapitre 10 Tubes et Tubes Nommés Les tubes sont un mécanisme de communication qui permet de réaliser des communications entre processus sous forme d un flot continu d octets. Les tubes sont un des éléments

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. É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étail

Communication par Signal - premiers pas

Communication par Signal - premiers pas Communication par Signal - premiers pas Quelques remarques sur la gestion des signaux UNIX ================================================== Un premier problème se pose lorsque plusieurs exemplaires d

Plus en détail

1 Création de processus : primitive fork()

1 Création de processus : primitive fork() O r s a y Travaux Pratiques n o 2 : Synchronisation DUT Informatique 2010 / 2011 Nom(s) : Groupe : Date : Objectifs : rappels sur la création de processus par la primitive fork() et synchronisation de

Plus en détail

Langage C et programmation système

Langage C et programmation système Langage C et programmation système DUT Informatique Villetaneuse Module : Système d'exploitation christophe.cerin@iutv.univ-paris13.fr Variables d environnement Votre problème : vous développez une application

Plus en détail

Programmation système en C/C++

Programmation système en C/C++ Programmation système en C/C++ Jean-Baptiste Vioix (jb.vioix@free.fr) LE2I - ENESAD http://jb.vioix.free.fr 1-41 Programmation en C/C++ sous Unix Il existe des très nombreux outils de développement sous

Plus en détail

NFA003 : L appel système fork

NFA003 : L appel système fork NFA003 : L appel système fork Amélie Lambert Sources : cours de NSY103 de Joëlle Delacroix 2013-2014 Amélie Lambert () NFA003 : L appel système fork 2013-2014 1 / 13 Création de processus Amélie Lambert

Plus en détail

DUT Informatique Module Système S4 C Département Informatique 2009 / 2010. Travaux Pratiques n o 2 : Communication

DUT Informatique Module Système S4 C Département Informatique 2009 / 2010. Travaux Pratiques n o 2 : Communication iut ORSAY DUT Informatique Département Informatique 2009 / 2010 Travaux Pratiques n o 2 : Communication Nom(s) : Groupe : Date : Objectifs : rappels sur la création de processus par la primitive fork()

Plus en détail

Projet du cours d ARCHITECTURE Gestion distribué d un parking

Projet du cours d ARCHITECTURE Gestion distribué d un parking Projet du cours d ARCHITECTURE Gestion distribué d un parking 3 GI, INSA de Lyon Janvier 2004 1 Objectifs du projet Ce projet a pour but d apprendre à manipuler une application multitâche où les différentes

Plus en détail

Le prototype de la fonction main()

Le prototype de la fonction main() Le prototype de la fonction main() 1. Introduction...1 2. Paramètres et type de retour de la fonction main()...1 3. Exemple 1...2 4. La fonction exit() du C...2 5. Détecter le code de retour d un programme

Plus en détail

Rapport de TP sur le mini-serveur HTTP. Maxime Chambreuil - Sébastien Le Digabel

Rapport de TP sur le mini-serveur HTTP. Maxime Chambreuil - Sébastien Le Digabel Rapport de TP sur le mini-serveur HTTP Maxime Chambreuil - Sébastien Le Digabel 16 janvier 2003 Table des matières 1 Détails sur nos travaux 2 1.1 But du TP............................. 2 1.2 La fonction

Plus en détail

TRAVAUX PRATIQUES Programmation Système

TRAVAUX PRATIQUES Programmation Système TRAVAUX PRATIQUES Programmation Système Langage C / Système UNIX. 1 ère année Génie Informatique Interface C/UNIX, appels système (NB Enoncés donnés en supplément des exemples et exercices du Poly) 1.

Plus en détail

M3101 Principes des systèmes d exploitation. Les tubes

M3101 Principes des systèmes d exploitation. Les tubes M Principes des systèmes d exploitation Les tubes IUT d Orsay DUT Informatique / 6 Les tubes Tube (pipe) un canal de communication entre les processus un flux d octets entre l entrée et la sortie accessible

Plus en détail

1 Exercice 1 Question de cours (3 points)

1 Exercice 1 Question de cours (3 points) Info32B Systèmes d'exploitations année 2012-2013 Partiel 26 février 2013 N. Sabouret & A. Methni L'épreuve dure 1h30. Tous les documents sont autorisés. Les exercices sont indépendants. 1 Exercice 1 Question

Plus en détail

UE NSY 103 Programmation Système. EXAMEN 2007-2008 Session Septembre. documents autorisés : Non. Session 2008 NSY 103 (S. Cherrier) Page 1 / 9

UE NSY 103 Programmation Système. EXAMEN 2007-2008 Session Septembre. documents autorisés : Non. Session 2008 NSY 103 (S. Cherrier) Page 1 / 9 UE NSY 103 Programmation Système EXAMEN 2007-2008 Session Septembre documents autorisés : Non Session 2008 NSY 103 (S. Cherrier) Page 1 / 9 Une sonde WEB L'équipe de développement dans laquelle vous travaillez

Plus en détail

Sujet d examen 1. Pratique du C. Novembre 2009

Sujet d examen 1. Pratique du C. Novembre 2009 Durée 1 h 30 Documents autorisés Sujet d examen 1 Pratique du C Novembre 2009 Introduction Écrivez lisiblement et n hésitez pas à commenter votre code en langage C. Vous ne pouvez utiliser que les fonctions

Plus en détail

Formation Unix/Linux (6) Le Shell: programmation et écriture de scripts

Formation Unix/Linux (6) Le Shell: programmation et écriture de scripts Formation Unix/Linux (6) Le Shell: programmation et écriture de scripts Olivier BOEBION Mars 2004 1 Les expressions conditionnelles et les structures de contrôle 1.1 La commande test La commande interne

Plus en détail

École Polytechnique de Montréal. Département de Génie Informatique. Cours INF3600 : Systèmes d exploitation. Contrôle périodique Automne 2001

École Polytechnique de Montréal. Département de Génie Informatique. Cours INF3600 : Systèmes d exploitation. Contrôle périodique Automne 2001 École Polytechnique de Montréal Département de Génie Informatique Cours INF3600 : Systèmes d exploitation Contrôle périodique Automne 2001 Date : 1 er novembre 2001 de 18h à 20h Professeurs : Kerly Titus,

Plus en détail

Introduction aux Systèmes et aux Réseaux

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/ Laure.Gonnord@univ-lyon1.fr Master CCI -

Plus en détail

LE concept de processus est le plus important dans un système d exploitation.

LE concept de processus est le plus important dans un système d exploitation. Chapitre 3 Processus LE concept de processus est le plus important dans un système d exploitation. Tout le logiciel d un ordinateur est organisé en un certain nombre de processus séquentiels. En simplifiant,

Plus en détail

I. Moniteur POP3 de emails en C

I. Moniteur POP3 de emails en C Année universitaire 2014/2015 Site : Luminy St-Charles St-Jérôme Cht-Gombert Aix-Montperrin Aubagne-SATIS Sujet de : 1 er semestre 2ème semestre Session 2 Examen de : L3 Code du module : SIN5U3 Calculatrices

Plus en détail

Formation Unix/Linux (3) Le Shell: gestion des processus, redirection d entrée/sortie

Formation Unix/Linux (3) Le Shell: gestion des processus, redirection d entrée/sortie Formation Unix/Linux (3) Le Shell: gestion des processus, redirection d entrée/sortie Olivier BOEBION Mars 2004 1 Définition Un programme se compose d un ou plusieurs fichiers composés d instructions.

Plus en détail

GESTION D UN FAST FOOD

GESTION D UN FAST FOOD GESTION D UN FAST FOOD LO41 Pierre ALAUZET Michael PALUMBO 15/01/2008 INTRODUCTION D ans le cadre de l UV LO41, il nous a été demandé de réaliser un projet mettant en œuvre des processus, ce qui correspond

Plus en détail

Réseau et Communication Notes de Cours/TD/TP autorisées; autres documents, calculettes, ordinateurs interdits.

Réseau et Communication Notes de Cours/TD/TP autorisées; autres documents, calculettes, ordinateurs interdits. Département d Informatique Faculté des Sciences de Luminy Réseau et Communication Lundi 9 mai 2011 Durée 3h Licence MI, UE INF15, E. Thiel Notes de Cours/TD/TP autorisées; autres documents, calculettes,

Plus en détail

Communication entre processus avec des tuyaux Fils Java. Partie A La communication entre processus avec tuyaux

Communication entre processus avec des tuyaux Fils Java. Partie A La communication entre processus avec tuyaux Systèmes d exploitation CSI3531 Labo 2 Communication entre processus avec des tuyaux Fils Java Partie A La communication entre processus avec tuyaux Objectif : Explorer le IPC avec les tuyaux UNIX/Linux

Plus en détail

Qu'est-ce qu'un processus: Définitions

Qu'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étail

Processus. Qu est ce qu un processus?

Processus. Qu est ce qu un processus? Qu est ce qu un processus? États d un processus Hiérarchie des processus Gestion des processus sous UNIX/LINUX Création de processus Remplacement d espace d adressage Attente de la fin d un processus fils

Plus en détail

Unix et Programmation Shell

Unix et Programmation Shell Unix et Programmation Shell Philippe Langevin départment d informatique UFR sciences et technique université du sud Toulon Var Automne 2013 Philippe Langevin (imath/ustv) Unix et Programmation Shell Automne

Plus en détail

Introduction Les arguments de main() Passons aux choses serieuses. Formation Linux. Adrien Chardon. Novembre 2014

Introduction Les arguments de main() Passons aux choses serieuses. Formation Linux. Adrien Chardon. Novembre 2014 Novembre 2014 1 Introduction 2 3 1 Introduction 2 Les deux prototypes possibles de main() Deux exemples pour comprendre 3 Exemples simples Explorateur de fichiers Connexion à distance Redirection et pipe

Plus en détail

Les processus. Système L3, 2014-2015 1/39

Les processus. Système L3, 2014-2015 1/39 Les processus Système L3, 2014-2015 1/39 Les processus Processus = Instance d un programme en cours d exécution plusieurs exécutions de programmes plusieurs exécutions d un même programme plusieurs exécutions

Plus en détail

Systèmes d'exploitation

Systèmes d'exploitation Université de Nice-Sophia Antipolis Examen L2 Info 20092010 Systèmes d'exploitation Nom : Prénom : Durée : 2h Nombre d'intercalaires : Note : NB : Vos réponses aux questions doivent être brèves et synthétiques.

Plus en détail

Compte en banque : Exemple de conception et implantation par raffinement successif

Compte en banque : Exemple de conception et implantation par raffinement successif Compte en banque : Exemple de conception et implantation par raffinement successif 11 octobre 2014 1 Énoncé On veut écrire un programme qui fait la mise à jour de votre compte en banque. Le programme traite

Plus en détail

CONSERVATOIRE NATIONAL DES ARTS ET METIERS

CONSERVATOIRE NATIONAL DES ARTS ET METIERS CONSERVATOIRE NATIONAL DES ARTS ET METIERS Durée : 2 heures METHODES DE PROGRAMMATION SYSTEMES UE NSY103 - NANCY/METZ INTERVENANT : E. DESVIGNE CORRECTION DE LA SESSION DE RATTRAPAGE 13/09/2011 Année 2010

Plus en détail

ISMIN 1A Programmation 1 : Examen de programmation C. Réponses. Partie 1. Questions ouvertes

ISMIN 1A Programmation 1 : Examen de programmation C. Réponses. Partie 1. Questions ouvertes ISMIN 1A Programmation 1 : Examen de programmation C Réponses Partie 1. Questions ouvertes 1. Soit la déclaration suivante, char tab[] = "". Que contient le tableau tab? Réponse : tab[0] = \0. tab est

Plus en détail

Le système de gestion des fichiers, les entrées/sorties.

Le système de gestion des fichiers, les entrées/sorties. Le système de gestion des fichiers, les entrées/sorties. Luigi Santocanale Laboratoire d Informatique Fondamentale, Centre de Mathématiques et Informatique, 39, rue Joliot-Curie - F-13453 Marseille 19

Plus en détail

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/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

Plus en détail

Programmation système I Les entrées/sorties

Programmation système I Les entrées/sorties Programmation système I Les entrées/sorties DUT 1 re année Université de Marne La vallée Les entrées-sorties : E/O Entrées/Sorties : Opérations d échanges d informations dans un système informatique. Les

Plus en détail

Traduction des arbres programmatiques en C

Traduction des arbres programmatiques en C Traduction des arbres programmatiques en C Table des matières 1 Premier exemple : helloworld.c 1 2 Méthode de programmation 2 3 Déclaration de variables 2 4 Structures de contrôle 3 5 Opérateurs C 5 6

Plus en détail

TP réseaux 4 : Installation et configuration d'un serveur Web Apache

TP réseaux 4 : Installation et configuration d'un serveur Web Apache TP réseaux 4 : Installation et configuration d'un serveur Web Apache Objectifs Installer, configurer, lancer et administrer le serveur Web Apache sous Linux Données de base machine fonctionnant sous Linux

Plus en détail

Réseau et Communication Notes de Cours/TD/TP autorisées; autres documents, calculettes, ordinateurs interdits.

Réseau et Communication Notes de Cours/TD/TP autorisées; autres documents, calculettes, ordinateurs interdits. Département d Informatique Faculté des Sciences de Luminy Réseau et Communication Vendredi 11 mai 2012 Durée 3h Licence MI, UE INF15, E. Thiel Notes de Cours/TD/TP autorisées; autres documents, calculettes,

Plus en détail

Réseau et Communication Notes de Cours/TD/TP autorisées; autres documents, calculettes, ordinateurs interdits.

Réseau et Communication Notes de Cours/TD/TP autorisées; autres documents, calculettes, ordinateurs interdits. Faculté des Sciences, AMU Licence d Informatique Réseau et Communication Jeudi 10 janvier 2013 Durée 2h UE SIN5U3 Sites Luminy et Aix Notes de Cours/TD/TP autorisées; autres documents, calculettes, ordinateurs

Plus en détail

Ligne de commande Linux avancée et scriptage bash (Linux 201)

Ligne de commande Linux avancée et scriptage bash (Linux 201) Ligne de commande Linux avancée et scriptage bash (Linux 201) laurent.duchesne@calculquebec.ca maxime.boissonneault@calculquebec.ca Université Laval - Septembre 2014 1 2 Se connecter à Colosse ssh colosse.calculquebec.ca

Plus en détail

École Polytechnique de Montréal. Département de Génie Informatique et Génie Logiciel. Cours INF2610. Noyau d un système d exploitation

École Polytechnique de Montréal. Département de Génie Informatique et Génie Logiciel. Cours INF2610. Noyau d un système d exploitation École Polytechnique de Montréal Département de Génie Informatique et Génie Logiciel Cours INF2610 Noyau d un système d exploitation Contrôle périodique Hiver 2013 Date : 25 février de 9h30 à 11h30 Professeurs

Plus en détail

TP N 2. Programmation des sockets

TP N 2. Programmation des sockets TP N 2. Programmation des sockets Exercice 1 : Troubleshooting de TCP & UDP - Que contient le fichier /etc/services? - Quels ports sont utilisés par les protocoles ftp, telnet, smtp, http? - Quel est le

Plus en détail

Commandes et scripts Bash. 1 Commandes de gestion des fichiers et répertoires

Commandes et scripts Bash. 1 Commandes de gestion des fichiers et répertoires Commandes et scripts Bash Seules certaines options sont indiquées. Pour plus de détails voir les pages de manuel (cf commande man). Si une commande est indiquée comme étant interne, cela signifie qu elle

Plus en détail

Interface des sockets

Interface des sockets Interface des sockets IUT Bordeaux I 08/12/2008 Interface des Sockets 1 A quoi servent les sockets? Applications client/serveur Transfert de fichiers, Connexion à distance, Courrier électronique, Groupe

Plus en détail

Modèle d exécution Exemple : le Motorola 68000

Modèle d exécution Exemple : le Motorola 68000 Mémoire et Processeur Mécanismes d exécution Du séquentiel au parallèle Modèle d exécution Exemple : le Motorola 68000 Registres de donnée Registres d adresse Registre d état Registre d état Compteur ordinal

Plus en détail

Examen de Langage C Vendredi 2 Décembre 2011

Examen de Langage C Vendredi 2 Décembre 2011 Année 2011-2012 Examen de Langage C Vendredi 2 Décembre 2011 Promotion Guichet 1 ière année É. Salvat Modalités : Durée : 2 heures Seul document autorisé : carte de référence du C, pas de machine à calculer,

Plus en détail

CHAPITRE 3 : Types de base, Opérateurs et Expressions

CHAPITRE 3 : Types de base, Opérateurs et Expressions CHAPITRE 3 : Types de base, Opérateurs et Expressions 1. Types simples Un type définit l'ensemble des valeurs que peut prendre une variable, le nombre d'octets à réserver en mémoire et les opérateurs que

Plus en détail

Les threads POSIX. Chapitre 16. 16.0.1 Description. 16.0.2 fork et exec

Les threads POSIX. Chapitre 16. 16.0.1 Description. 16.0.2 fork et exec Chapitre 16 Les threads POSIX La programmation par thread (actvité) est naturelle pour gérer des phénomènes asyncrones. Les entrées utilisateur dans les interfaces graphiques (souris, clavier) sont plus

Plus en détail

Langages et concepts de programmation

Langages et concepts de programmation Langages et concepts de programmation Séances 3 et 4 Tri d un fichier de voitures Une correction possible 1 Le sujet On dispose d un fichier contenant des informations sur des voitures d occasion : le

Plus en détail

Cours de Réseau et communication Unix n 4

Cours de Réseau et communication Unix n 4 Cours de Réseau et communication Unix n 4 Edouard THIEL Faculté des Sciences Université d Aix-Marseille (AMU) Septembre 2014 Les transparents de ce cours sont téléchargeables ici : http://pageperso.lif.univ-mrs.fr/~edouard.thiel/ens/rezo/

Plus en détail

1. BASH - Programmation en SHELL...21

1. BASH - Programmation en SHELL...21 Table des matières Programmation en SHELL BASH sous Linux...3 1. Présentation...3 2. Avant de commencer...3 2.1. L interpréteur...4 2.2. Le quoting...4 2.3. Les structures de contrôles...4 2.3.1. for...5

Plus en détail

Interfaçage de programmation. c Olivier Caron

Interfaçage de programmation. c Olivier Caron Interfaçage de programmation 1 Le SGBD est-il suffisant? (1/2) Les pour : La puissance du langage de requêtes. 1 Le SGBD est-il suffisant? (1/2) Les pour : La puissance du langage de requêtes. L aspect

Plus en détail

M3101 Principes des systèmes d exploitation. Les fichiers

M3101 Principes des systèmes d exploitation. Les fichiers M3101 Principes des systèmes d exploitation Les fichiers IUT d Orsay DUT Informatique 2015 / 2016 Les fichiers, les processus et le noyau A 0 1 2 3 4 5 entrée sortie erreur descripteurs de fichiers attributs

Plus en détail

Programmation Avancée en Langage C Séances de Travaux-Pratiques

Programmation Avancée en Langage C Séances de Travaux-Pratiques Programmation Avancée en Langage C Séances de Travaux-Pratiques Ph. Langevin Année Universitaire 2010 Contents 1 Préambule 2 2 Commandes de base 2 2.1 man................................ 2 2.2 Recherche.............................

Plus en détail

DUT Informatique Module Système S4 C Département Informatique 2009 / 2010. Travaux Pratiques n o 5 : Sockets Stream

DUT Informatique Module Système S4 C Département Informatique 2009 / 2010. Travaux Pratiques n o 5 : Sockets Stream iut ORSAY DUT Informatique Département Informatique 2009 / 2010 Travaux Pratiques n o 5 : Sockets Stream Nom(s) : Groupe : Date : Objectifs : manipuler les primitives relatives à la communication par sockets

Plus en détail

INTRODUCTION AUX SYSTEMES D EXPLOITATION. TD1/TP1 Création et terminaison des processus

INTRODUCTION AUX SYSTEMES D EXPLOITATION. TD1/TP1 Création et terminaison des processus INTRODUCTION AUX SYSTEMES D EXPLOITATION TD1/TP1 Création et terminaison des processus Création et terminaison des processus - 0.1 - S O M M A I R E 1. LA PRIMITIVE FORK ()... 1 1.1. DESCRIPTION DU FORK

Plus en détail

Introduction au langage C - types et variables

Introduction au langage C - types et variables Chapitre 2 Introduction au langage C - types et variables 1 Le Langage C Le langage C est un langage de bas niveau dans le sens où il permet l accès à des données que manipulent les ordinateurs (bits,

Plus en détail

Programmation système : tampons

Programmation système : tampons Programmation système : tampons Juliusz Chroboczek 12 Octobre 2009 1 Tampons Le programme de copie décrit au cours précédent effectue deux appels système pour chaque octet copié ce qui est tragique. Une

Plus en détail

Communication par tubes

Communication par tubes Communication par tubes Polytech Paris-Sud Cycle ingénieur de la filière étudiant Louis Mandel Université Paris-Sud 11 Louis.Mandel@lri.fr année 2012/2013 Communication inter-processus : les tubes (pipes)

Plus en détail

Programmation C++ (débutant)/les fichiers

Programmation C++ (débutant)/les fichiers Programmation C++ (débutant)/les fichiers 1 Programmation C++ (débutant)/les fichiers Généralité sur les fichiers La règle générale pour créer un fichier est la suivante : il faut l'ouvrir en écriture.

Plus en détail

synchronisation et communication entre processus Synchronisation et communication entre processus

synchronisation et communication entre processus Synchronisation et communication entre processus 1 Synchronisation et communication entre processus Accès à des ressources communes 2 Exemple: compte bancaire dont montant en A sur disque programme pour ajouter 100: lire(n,a) N := N+100 écrire(n,a) 2

Plus en détail

2 Utilisation d un tube par plusieurs processus

2 Utilisation d un tube par plusieurs processus O r s a y Travaux Pratiques n o 3 : Sémaphores DUT Informatique 2010 / 2011 Nom(s) : Groupe : Date : Objectifs : être capable de construire des applications dont le mécanisme d exclusion mutuelle repose

Plus en détail

Processus. Les processus, à quoi ça sert? Une définition d'un processus. La vie intime des processus. Allocation du processeur

Processus. Les processus, à quoi ça sert? Une définition d'un processus. La vie intime des processus. Allocation du processeur 1 sur 9 Processus Les processus, à quoi ça sert? Une définition d'un processus La vie intime des processus Quelques caractéristiques des processus Le contexte et la commutation de contexte Les processus

Plus en détail

Daisylab.fr POURQUOI

Daisylab.fr POURQUOI POURQUOI POURQUOI La porte du garage s ouvre-t-elle? L ouverture de la porte du garage est une illustration d un principe de base de l automatisme : INFORMATION ( CAPTEUR ) TRAITEMENT INFORMATION ( MICROCONTROLEUR)

Plus en détail

Programmation Système En C sous Linux (Debian et Ubuntu)

Programmation Système En C sous Linux (Debian et Ubuntu) Programmation Système En C sous Linux (Debian et Ubuntu) Rémy Malgouyres LIMOS UMR 6158, IUT, département info Université Clermont 1 B.P. 86 63172 AUBIERE cedex http://malgouyres.org Une version HTML de

Plus en détail

Introduction à Lex et Yacc

Introduction à Lex et Yacc Introduction à Lex et Yacc H. Cassé, M. Couzinier, M. Strecker Année 2004/2005 1. L analyseur lexical Lex 2. L analyseur syntaxique Yacc 3. La coordination de Lex et Yacc 1 Processus de compilation programme

Plus en détail

Introduction au langage C

Introduction au langage C Introduction au langage C Cours 1: Opérations de base et premier programme Alexis Lechervy Alexis Lechervy (UNICAEN) Introduction au langage C 1 / 23 Les premiers pas Sommaire 1 Les premiers pas 2 Les

Plus en détail

Organigramme GNS Langage C

Organigramme GNS Langage C L organigramme Principe de lecture L organigramme débute par le symbole début et se termine au symbole fin. Entre ces deux symboles, il faut suivre le chemin tracé. Symboles de base Entrée ou sortie: Start

Plus en détail

Le langage php. Serveur http est automatiquement lancé.

Le langage php. Serveur http est automatiquement lancé. Le langage php 1. Introduction aux langages serveurs : Il y a deux modes d exécution d une page HTML : Local : en cliquant sur le fichier, le navigateur Serveur http est automatiquement lancé. Navigateur

Plus en détail

Chapitre 4: Gestion des processus

Chapitre 4: Gestion des processus Chapitre 4: Gestion des processus Version Septembre 2011 N 187 Plan de travail Qu'est-ce qu'un processus? concept, identification concept, identification Création de processus Description d'un processus

Plus en détail

TP Interface graphique et C++ numéro 1

TP Interface graphique et C++ numéro 1 TP Interface graphique et C++ numéro 1 Master IGC - 1 re année année 2010-2011 Ce premier TP a pour objectif de vous familiariser avec le compilateur C++, les entréessorties du langage et l utilisation

Plus en détail

PLAN DU COURS ENTRÉE SORTIE FONCTION PRINTF. Fonction de la bibliothèque stdio.h. Affichage d'un texte:

PLAN DU COURS ENTRÉE SORTIE FONCTION PRINTF. Fonction de la bibliothèque stdio.h. Affichage d'un texte: PLAN DU COURS Introduction au langage C Notions de compilation Variables, types, constantes, Tableaux, opérateurs Entrées sorties de base Structures de contrôle Algorithmes de recherche Algorithmes de

Plus en détail

Merci à Arnaud dupont

Merci à Arnaud dupont Merci à Arnaud dupont Système d exploitation Un système d exploitation exploite quoi? Les systèmes d exploitation - introduction - C est l interface entre l utilisateur et le matériel Ses fonctions principales

Plus en détail

Logiciels de Base. 2ème partie: Logiciels de base. Cours 1ère année informatique, semestre 1. Najib Tounsi

Logiciels de Base. 2ème partie: Logiciels de base. Cours 1ère année informatique, semestre 1. Najib Tounsi Logiciels de Base 2ème partie: Logiciels de base Cours 1ère année informatique, semestre 1. Najib Tounsi Lien permanent: http://www.emi.ac.ma/~ntounsi/cours/logbase/logicielsdebase-2.html 1. Les produits

Plus en détail

Structure arborescente de fichiers. Fichiers. Types de fichiers. Systèmes de fichiers. Wieslaw Zielonka. October 2, 2014 media

Structure arborescente de fichiers. Fichiers. Types de fichiers. Systèmes de fichiers. Wieslaw Zielonka. October 2, 2014 media Structure arborescente de fichiers / bin dev home etc Fichiers bash bunzip tar sda tty3 tom mike peter postgresql python Wieslaw Zielonka enseignement Systemes 9 93 October, 04 media courspdf courstex

Plus en détail

Programmation Unix Notes de Cours/TD/TP autorisées; autres documents, calculettes, ordinateurs interdits.

Programmation Unix Notes de Cours/TD/TP autorisées; autres documents, calculettes, ordinateurs interdits. Département d Informatique Faculté des Sciences de Luminy Programmation Unix Vendredi 17 décembre 2010 Durée 3h Licence MI, UE INF5, resp. E. Thiel Notes de Cours/TD/TP autorisées; autres documents, calculettes,

Plus en détail

Dans un fichier «counter.c» (attention c'est du pseudo C) int count = 0; int exit = 0;

Dans un fichier «counter.c» (attention c'est du pseudo C) int count = 0; int exit = 0; Plan Unix et Programmation Web Cours 2 kn@lri.fr http://www.lri.fr/~kn 1 Systèmes d'exploitation (1/2) 2 Systèmes d'exploitation (2/2) 2.1 Gestion des processus 2.2 Écriture de script shell 2.3 Programmes

Plus en détail

Systèmes d exploitation

Systèmes d exploitation Cours no. 7 Jean-Sébastien Coron Université du Luxembourg coron@clipper.ens.fr Communications inter-processus Méthodes de communications inter-processus: Les signaux. Pas de données transmises. Les tuyaux:

Plus en détail

Multi-Processing - premiers pas

Multi-Processing - premiers pas Multi-Processing - premiers pas Exercice 1 : Exécution concurrente des processus père et fils Ecrire un programme qui crée un fils. Le père affiche : «Je suis le père mon PID est... et mon PPID est...».

Plus en détail

Plan. Le système de gestion des fichiers, (II) Contenu d un répertoire (/etc) (Bach 1988) i-noeud + contenu. Luigi Santocanale.

Plan. Le système de gestion des fichiers, (II) Contenu d un répertoire (/etc) (Bach 1988) i-noeud + contenu. Luigi Santocanale. Plan Le système de gestion des fichiers, (II) Luigi Santocanale Laboratoire d Informatique Fondamentale, Centre de Mathématiques et Informatique, 39, rue Joliot-Curie - F-13453 Marseille 25 octobre 2005

Plus en détail

IN3T01 Programmation C TP 2 corrigé Jean-Claude Georges - Michel Landschoot

IN3T01 Programmation C TP 2 corrigé Jean-Claude Georges - Michel Landschoot ESIEE 2011 2012 IN3T01 Programmation C TP 2 corrigé Jean-Claude Georges - Michel Landschoot PARTIE 1: LES FONCTIONS ET LES POINTEURS fichier fonctions.h #ifndef _FONCTION_H_ #define _FONCTION_H_ #include

Plus en détail