TP7. init.c #include<stdio.h> #include<sys/types.h> #include<stdlib.h> #include<errno.h> #include<sys/ipc.h> #include<sys/msg.

Save this PDF as:
 WORD  PNG  TXT  JPG

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

Download "TP7. init.c #include<stdio.h> #include<sys/types.h> #include<stdlib.h> #include<errno.h> #include<sys/ipc.h> #include<sys/msg."

Transcription

1 TP7 init.c #include<stdio.h> #include<sys/types.h> #include<stdlib.h> #include<errno.h> #include<sys/ipc.h> #include<sys/msg.h> #define CLE 555 int msqid; if((msqid=msgget((key_t) CLE,IPC_CREAT 0666))==-1)//creation de la file de message perror("echec de msgget"); printf("identificateur interne de la file : %d\n",msqid);//recuperation des caractã ristique de la file printf("cette file est identifiee par la cle unique : %d\n",(key_t)cle); exit(0); message.h #ifndef MESSAGE_H #define MESSAGE_H #include<stdio.h> #include<string.h> #include<sys/types.h> #include<stdlib.h> #include<errno.h> #include<sys/ipc.h> #include<sys/msg.h> #define CLE 555 typedef struct int numero;//numero de l'etudiant char nom[10]; float notes[5]; char MPass[10]; ETUDIANT; typedef struct long type;//type du message long pid;//le pid du processus client char commande; ETUDIANT etudiant; short resultat; MESSAGE; void init(); int getmsgid(); #endif

2 message.h void init() int msqid; if((msqid=msgget((key_t) CLE,IPC_CREAT 0666))==-1) perror("echec de msgget"); printf("identificateur interne de la file : %d\n",msqid); printf("cette file est identifiee par la cle unique : %d\n",(key_t)cle); int getmsgid(void) int id; if((id=msgget((key_t) CLE,IPC_CREAT 0666))==-1) perror("echec de msgget"); return id; serveur.c #include<stdio.h> MESSAGE mess; ETUDIANT etud[3]; int msqid,i; //initialisation de trois etudiants etud[0].numero=0; etud[1].numero=1; etud[2].numero=2; strcpy(etud[0].nom,"tata"); strcpy(etud[1].nom,"tete"); strcpy(etud[2].nom,"titi"); strcpy(etud[0].mpass,"tata"); strcpy(etud[1].mpass,"tete"); strcpy(etud[2].mpass,"titi"); etud[0].notes[0]=01;etud[0].notes[1]=02;etud[0].notes[2]=03;etud[0].notes[3]=04;etud[0].notes[4]=05; etud[1].notes[0]=11;etud[1].notes[1]=12;etud[1].notes[2]=13;etud[1].notes[3]=14;etud[1].notes[4]=15; etud[2].notes[0]=21;etud[2].notes[1]=22;etud[2].notes[2]=23;etud[2].notes[3]=24;etud[2].notes[4]=25; init(); msqid=getmsgid(); int type=0; while(1)//reception message; msgrcv(msqid,&mess,sizeof(mess),-2,0); if (mess.type==1)//cote enseignant printf("je gere un enseignant\n"); mess.etudiant=etud[mess.etudiant.numero];//on recupere les donnees enregistree dans la structure printf("num de l'etudiant : %d\n",mess.etudiant.numero); for(i=0;i<=4;i++) etud[mess.etudiant.numero].notes[i]=mess.etudiant.notes[i];//recuperation note par note printf("."); printf("notes recuperees\n"); mess.resultat=0; mess.type=mess.pid;

3 //envoie des donnees relative a l'etudiant à l'enseignant printf("fin de l'envoi des notes initiales\n\n"); //attente du message avec une note modifiee type=0; while(type!=1)//pour éviter de recevoir un message d'un etudiant. c'est la raison pour laquel ca bloque cote etudiant. msgrcv(msqid,&mess,sizeof(mess),-2,0); if(mess.type==1) type=1; //c'est ici qu'il faudrait recupere les donnees, sans avoir bloque l'etudiant printf("seconde reception du serveur\n"); //on est toujours sur le meme etudiant : pas besoin d'aller chercher des donnees printf("num de l'etudiant : %d",mess.etudiant.numero); for(i=0;i<=4;i++) printf("\n **notes modifiees** %d : ",i+1); etud[mess.etudiant.numero].notes[i]=mess.etudiant.notes[i]; printf("%f",mess.etudiant.notes[i]); printf("\n"); mess.resultat=0; mess.type=mess.pid; //envoie des nouvelles notes printf("fin de l'envoi\n\n\n\n"); printf("j'ai termine avec l'enseignant\n***********************\n\n"); if(mess.type==2)//coté etudiant printf("je gere un etudiant\n"); char motdepasse[10]; return 0; strcpy(motdepasse,mess.etudiant.mpass);//on recupere tout d'abord le mot de passe entre mess.resultat=0; mess.type=mess.pid; if(strcmp(motdepasse,etud[mess.etudiant.numero].mpass)==0) mess.etudiant=etud[mess.etudiant.numero];//si bon mot de passe, alors envoi des donnes else mess.resultat=1;//on renvoie une erreur, et pas les notes printf("j'ai termine avec l'etudiant\n**************************\n\n");

4 enseignant.h //on a reussi a faire en sorte (au niveau du serveur) que si un enseignant a pris la main, alors le serveur fini de s'occuper de lui, pour ne pas perdre les infos sur l'etudiant manipuler. Le probleme est donc qu'un etudiant ne peut pas consulter si un enseignant modifie les notes. //une solution pourrait etre de sauvegarder les donnees (cote serveur) et les recuperer apres reception du message de type 1 (enseignant) #include <unistd.h> int msqid,num,i,note; char com; char buf; MESSAGE mess; msqid=getmsgid(); while (1) printf("ecrire Notes (E) ou Quitter(Q)?\n"); scanf("%c",&com); if(com=='e' com=='e') printf("numero de l'etudiant (0,1 ou 2)?\n");//choix de l'etudiant pour afficher ses notes ensuite scanf("%d",&num); //sert a vider le buffer mess.etudiant.numero=num;//parametrage du message mess.type=1; mess.pid=getpid(); mess.resultat=-1; printf("envoi des informations\n"); //envoie du message au serveur pour lui indiquer l'étudiant 'manipule' if(msgsnd(msqid,&mess,(sizeof(mess)-sizeof(long)),0)==-1) perror("impossible d'envoyer le message"); //on recoit les donnees relatives a l'etudiant : les notes msgrcv(msqid,&mess,sizeof(mess)-sizeof(mess.type), mess.pid,0); if(mess.resultat!=-1) printf("etudiant numero %d\n",mess.etudiant.numero);//boucle d'affichage des notes de l'etudiant for(i=0;i<5;i++) printf("notes%d: %f\n",i+1,mess.etudiant.notes[i]); //modification d'une note printf("\nnumero de la note a modifier (1 a 5) : \n"); scanf("%d",&num); printf("nouvelle note : "); scanf("%d",&note); mess.type=1;//parametrage du message mess.etudiant.notes[num-1]=note; //envoi de la valeur perror("impossible d'envoyer le message depuis enseignant"); msgrcv(msqid,&mess,sizeof(mess)-sizeof( mess.type), mess.pid,0);//notes recus if(mess.resultat!=-1) printf("apres modification :\n");

5 for(i=0;i<5;i++) printf("notes %f\n",mess.etudiant.notes[i]);//affichage de ses notes else //pas de saisie protegee pour quitter exit(0); return 0; etudiant.c //le probleme de ce code est que si l'enseignant est en train de modifier un etudiant, alors l'execution de etudiant est bloquée (on ne peut que l'arreter avec ctrl+z) //les donnes concernant un etudiant sont codes en statique dans serveur.c #include <unistd.h> char mdp[10]; int msqid,num,i; char com; char buf; MESSAGE mess; msqid=getmsgid(); while (1) printf("consulter Notes (C) ou Quitter(Q)?\n"); scanf("%c",&com); if(com=='c' com=='c') //on va d'abord envoyer le numã ro de l'etudiant avec un mot de passe. si ca correspond, alors on affiche les notes. sinon, on recommence la boucle. (pas de compteur de nombre d'erreur printf("numero de l'etudiant (0,1 ou 2)?\n"); scanf("%d",&num); //vidage du buffer printf("mot de passe : "); scanf("%s",mdp); mess.etudiant.numero=num;//copie des donnees pour les comparer ensuite, au niveau du serveur strcpy(mess.etudiant.mpass,mdp); mess.type=2; mess.pid=getpid(); mess.resultat=-1; printf("envoi des informations\n"); l'ã tudiant 'manipule' if(msgsnd(msqid,&mess,(sizeof(mess)-sizeof(long)),0)==-1)//envoie du message au serveur pour lui indiquer perror("impossible d'envoyer le message"); msgrcv(msqid,&mess,sizeof(mess)-sizeof(mess.type), mess.pid,0);//on recoit soit les donnees relatives a l'etudiant, soit une erreur (si mess.resultat = 1)

6 else return (0); if(mess.resultat==1) printf("erreur de Mot de passe\n"); if(mess.resultat==0)//bon mot de passe printf("etudiant numero %d\n",mess.etudiant.numero);//affichage de l'etudiant //boucle d'affichage des notes for(i=0;i<5;i++) printf("notes %f\n",mess.etudiant.notes[i]); exit(0); makefile all: serveur delete enseignant init etudiant delete: message.o delete.o gcc -o delete message.o delete.o serveur: message.o serveur.o gcc -o serveur message.o serveur.o init: init.o gcc -o init init.o enseignant: message.o enseignant.o gcc -o enseignant message.o enseignant.o etudiant: etudiant.o etudiant.o gcc -o etudiant message.o etudiant.o message.o: message.c gcc -o message.o -c message.c -g -Wall delete.o: delete.c message.h gcc -o delete.o -c delete.c -g -Wall serveur.o: serveur.c message.h gcc -o serveur.o -c serveur.c -g -Wall enseignant.o: enseignant.c message.h gcc -o enseignant.o -c enseignant.c -g -Wall etudiant.o: etudiant.c message.h gcc -o etudiant.o -c etudiant.c -g -Wall init.o: init.c gcc -o init.o -c init.c -g -Wall clean : rm -rf *.o

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

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

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

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

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

TRAVAUX PRATIQUES Programmation Système Langage C / Système UNIX. 2 e année Génie Informatique 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

Plus en détail

communication interprocessus

communication interprocessus communication interprocessus Novembre 2008 On examine deux autres moyens de communication interprocessus offerts par les systèmes autres que les tubes : file de message, mémoire partagés. Un dernier moyen

Plus en détail

I Quelques points d'algorithmique

I Quelques points d'algorithmique I Quelques points d'algorithmique 1) Types Type "simple" : Identificateur commençant par une majuscule = Description du type Les principaux types : les entiers naturels (int, long, long long) ou relatifs

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

MISE A NIVEAU INFORMATIQUE LANGAGE C - EXEMPLES DE PROGRAMMES. Université Paris Dauphine IUP Génie Mathématique et Informatique 2 ème année

MISE A NIVEAU INFORMATIQUE LANGAGE C - EXEMPLES DE PROGRAMMES. Université Paris Dauphine IUP Génie Mathématique et Informatique 2 ème année 2003-2004 Université Paris Dauphine IUP Génie Mathématique et Informatique 2 ème année MISE A NIVEAU INFORMATIQUE LANGAGE C - EXEMPLES DE PROGRAMMES Maude Manouvrier La reproduction de ce document par

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

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

1 Entête des fonctions

1 Entête des fonctions Le lecteur rédacteur est un problème de synchronisation qui suppose que l on peut accéder aux données partagées de 2 manières : en lecture, c est a dire sans possibilité de modification; en écriture. Il

Plus en détail

LO41 A06 Projet 7 Montre digitale

LO41 A06 Projet 7 Montre digitale LO41 A06 Projet 7 Montre digitale Binôme : Haffner Alexandre Monneret Nicolas Enoncé : Il s agit de simuler le fonctionnement d une montre digitale comprenant une horloge interne, mise à jour périodiquement

Plus en détail

Série d exercices. o Cas 2 : gcc o nomexecutable c nomsource.c. o Cas 3 : gcc o nomexecutable W -Wall nomsource.c

Série d exercices. o Cas 2 : gcc o nomexecutable c nomsource.c. o Cas 3 : gcc o nomexecutable W -Wall nomsource.c Langage Impératif 1 TP 1 du 11 octobre 2010 Série d exercices Rappels rapides : - Un programme C s écrit toujours dans un fichier d extension.c (en minuscule!! sinon ce serait compilé comme du C++). Ce

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

C, seconde séance. le if then else n est pas une expression, mais une instruction ( Caml) se souvenir de:

C, seconde séance. le if then else n est pas une expression, mais une instruction ( Caml) se souvenir de: C, seconde séance le if then else n est pas une expression, mais une instruction ( Caml) se souvenir de: false, c est 0 ( \0 aussi) test d égalité: == pour printf: %d entier, %f flottant, %c caractère,

Plus en détail

Principes de la programmation impérative

Principes de la programmation impérative Séquence d instructions Variables et types Types élaborés Procédures, arguments Gestion de la mémoire Langage compilé, interprété Principes de la programmation impérative Séquence d instructions Variables

Plus en détail

Projet UML. Gestion d'un distributeur de carburant. BOUSQUET Nicolas GAYRARD Jérémy

Projet UML. Gestion d'un distributeur de carburant. BOUSQUET Nicolas GAYRARD Jérémy Projet UML Gestion d'un distributeur de carburant BOUSQUET Nicolas GAYRARD Jérémy Présentation : Étude préliminaire Définir les besoins : 3:*gérer listes abonnés 2:*gérer les prix 1:*gérer les pompes 1:*Distribuer

Plus en détail

intro aux SE et mise en œuvre sous UNIX

intro aux SE et mise en œuvre sous UNIX TP: Programmer sous GNU/LINUX Ce premier TP introductif à la programmation en C va vous familiariser avec : la syntaxe du langage ; la mise en oeuvre du compilateur ; le préprocesseur cpp ; l'utilisation

Plus en détail

EVALUATION D UNE EXPRESSION ARITHMETIQUE POSTFIXEE

EVALUATION D UNE EXPRESSION ARITHMETIQUE POSTFIXEE EVALUATION D UNE EXPRESSION ARITHMETIQUE POSTFIXEE Les expressions arithmétiques sont habituellement écrites de manière infixe, c'est à dire que l'opérateur est placé entre ses deux opérandes (ou avant

Plus en détail

Archivage Messagerie Evolution pour usage HTML en utilisant Hypermail

Archivage Messagerie Evolution pour usage HTML en utilisant Hypermail Finalités Archivage Messagerie Evolution pour usage HTML en utilisant Hypermail Réalisé par sa modestie Arnaud de VILLEDON de NAIDE, le 9 mars 2013 Document sous licence GPL. Vous avez le droit d'en faire

Plus en détail

GL / C++ Chapitre 7. Lien Dynamique Méthodes Virtuelles

GL / C++ Chapitre 7. Lien Dynamique Méthodes Virtuelles GL / C++ Chapitre 7 Lien Dynamique Méthodes Virtuelles 1. Pointeur sur un objet d'une classe dérivée Considérons les classes écrites précédemment : Personne Etudiant // dérive de personne Salarie // dérive

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

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

Projet réseau : un «petit» client ftp

Projet réseau : un «petit» client ftp Projet 2005-2006 Client FTP Manuel Technique Projet réseau : un «petit» client ftp Maquaire Myriam Jilibert Laurent L3 GMI Resp : Mr Guesnet Sommaire 1) Aperçu du protocole FTP. 3 2) Historique... 4 3)

Plus en détail

Année 2012-2013 Licence 2 TD 6. Synchronisation et Sémaphores

Année 2012-2013 Licence 2 TD 6. Synchronisation et Sémaphores Institut Galilée Systèmes d exploitation et Réseaux Année 2012-2013 Licence 2 TD 6 Synchronisation et Sémaphores 1 Synchronisation : le coiffeur Une illustration classique du problème de la synchronisation

Plus en détail

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

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

1 : 1 er programmes & prise en main de l environnement

1 : 1 er programmes & prise en main de l environnement 1 : 1 er programmes & prise en main de l environnement 1 Introduction 1.1 Rappel : gestion d arborescence et de fichiers sous UNIX Pour la manipulation de répertoire et de fichier à partir d un terminal

Plus en détail

Pompes carburant - Phase d analyse

Pompes carburant - Phase d analyse Pompes carburant - Phase d analyse V. Diagramme de séquence (associé au CU FournirCarburant) Client / Pupitre LecteurCarte Pompes Service Imprimante Carte TaperCode Code-client Client_ok ChoisirCarbu TypeCarbu

Plus en détail

Programmation Impérative 2006-2007

Programmation Impérative 2006-2007 Programmation Impérative 2006-2007 Licence Physique-Applications, Phisique-Chimie Université Jean Monnet Ruggero G. PENSA ruggero.pensa@univ-st-etienne.fr Définition de nouveaux types En pseudo-langage

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

Introduction à Make et aux fonctions pseudo-aléatoires

Introduction à Make et aux fonctions pseudo-aléatoires Introduction à Make et aux fonctions pseudo-aléatoires 1 Introduction à Make Support de TP C Make est un outil de programmation, dont une version est disponible pour les systèmes Unix sous la licence GNU

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

char (1) short (2) int (4) long int (8) long long int (8) unsigned char unsigned int unsigned short unsigned long int unsigned long long int

char (1) short (2) int (4) long int (8) long long int (8) unsigned char unsigned int unsigned short unsigned long int unsigned long long int char (1) short (2) int (4) long int (8) long long int (8) unsigned char unsigned int unsigned short unsigned long int unsigned long long int float (4) double (8) long double (16) char* (8) int* (8)...

Plus en détail

CARLIER Julien Année 2005-2006 PATRIE Thomas P. KADIONIK Groupe GA 26. Projet Réseau. Programmation d un mini serveur WEB

CARLIER Julien Année 2005-2006 PATRIE Thomas P. KADIONIK Groupe GA 26. Projet Réseau. Programmation d un mini serveur WEB CARLIER Julien Année 2005-2006 PATRIE Thomas P. KADIONIK Groupe GA 26 Projet Réseau Programmation d un mini serveur WEB Sommaire... 1 Introduction... 2 2 Cahier des charges... 3 2.1 Les taches réalisées

Plus en détail

3ETI, Entrainement Examen [CSC2] Developpement Logiciel en C CPE Lyon

3ETI, Entrainement Examen [CSC2] Developpement Logiciel en C CPE Lyon 3ETI, Examen [CSC2] Developpement Logiciel en C CPE Lyon 2012-2013 (entrainement) durée 1h20 Tous documents et calculatrices autorisés. Le sujet comporte 5 pages Le temps approximatif ainsi que le barème

Plus en détail

Liste des dossiers avec profondeur

Liste des dossiers avec profondeur Liste des dossiers avec profondeur A Ce que l'on veut Avoir une commande de type 'ls R' qui n'affiche que les dossiers non cachés, sans les liens symboliques, jusqu'à une certaine profondeur. Le but étant

Plus en détail

Etude de cas simulation de banque UML/C++

Etude de cas simulation de banque UML/C++ Etude de cas simulation de banque UML/C++ Philippe Laroque $Id: simubanque.lyx 1665 2009-03-05 16:02:45Z phil $ laroque@u-cergy.fr mars 2009 Abstract Ce petit document résume, à travers une étude de cas

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

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

INF 201 - TP 2 - Programmation C T. Grandpierre 12/2008

INF 201 - TP 2 - Programmation C T. Grandpierre 12/2008 INF 201 - TP 2 - Programmation C T. Grandpierre 12/2008 Ce qu il faut rendre : A la fin du TP il faudra archiver et compresser l ensemble de votre travail (y compris le rapport avec vos noms) avec la commande

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

/* ================================================ ================== */ /* ================================================ ================== */

/* ================================================ ================== */ /* ================================================ ================== */ tp.c Fichier pour travaux pratiques de maitrise Universite Paul Sabatier --- rappel des bits de donnes du port parallele pour Audine ordre : 87654321 bit 1 : horloge V1 bit 2 : horloge V2 bit 3 : horloge

Plus en détail

Noyau d'un système d'exploitation INF2610 Chapitre 7 : Gestion de la mémoire (annexe 2)

Noyau d'un système d'exploitation INF2610 Chapitre 7 : Gestion de la mémoire (annexe 2) INF2610 Chapitre 7 : Gestion de la mémoire (annexe 2) Département de génie informatique et génie logiciel Hiver 2014 Exemple 1 : Espace virtuel d un processus Où seront stockées les données des variables

Plus en détail

Les structures de données. Rajae El Ouazzani

Les structures de données. Rajae El Ouazzani Les structures de données Rajae El Ouazzani Les arbres 2 1- Définition de l arborescence Une arborescence est une collection de nœuds reliés entre eux par des arcs. La collection peut être vide, cad l

Plus en détail

Tri par tas. 1 Élément et tableau TP 4. Année

Tri par tas. 1 Élément et tableau TP 4. Année Sup Galilée Année 2015-2016 Algorithmique CP2I2 TP 4 Tri par tas 1 Élément et tableau Veuillez utiliser les types et fonctions suivants pour manipuler les éléments et les tableaux. Fichier element.c :

Plus en détail

Chapitre 1 Introduction

Chapitre 1 Introduction Chapitre 1 Introduction Jean Privat Université du Québec à Montréal INF7330 Construction de logiciels Diplôme d études supérieures spécialisées en systèmes embarqués Automne 2012 Jean Privat (UQAM) 01

Plus en détail

Algorithmique et Structures de Données

Algorithmique et Structures de Données Plan du cours Algorithmique et Structures de Données Akkouche Samir : E-mail : samir.akkouche@liris.cnrs.fr Knibbe Carole: E-mail : carole.knibbe@univ-lyon1.fr 1. Rappels 2. Tableaux dynamiques a. Introduction

Plus en détail

3ETI, Examen [CSC2] Developpement Logiciel en C CPE Lyon

3ETI, Examen [CSC2] Developpement Logiciel en C CPE Lyon 3ETI, Examen [CSC2] Developpement Logiciel en C CPE Lyon 2014-2015 (1ere session) durée 3h Tous documents et calculatrices autorisés. Répondez aux questions sur une copie séparée Le sujet comporte 8 pages

Plus en détail

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

1. Structure d un programme C. 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étail

Université Paris 7 IUP2 Année 2004-2005. Structures de contrôle. Exercice 1 Ecrire et sauvegarder le programme suivant sous le nom premiers_pas.

Université Paris 7 IUP2 Année 2004-2005. Structures de contrôle. Exercice 1 Ecrire et sauvegarder le programme suivant sous le nom premiers_pas. Université Paris 7 C IUP2 Année 2004-2005 TD n 1 - Correction Structures de contrôle Exercice 1 Ecrire et sauvegarder le programme suivant sous le nom premiers_pas.c : int main(void) { int resultat ; int

Plus en détail

La programmation Impérative par le Langage C

La programmation Impérative par le Langage C La programmation Impérative par le Langage C 1. Introduction 1.1 Qu est-ce que la programmation impérative? Un programme est constitué de plusieurs lignes d instructions. Chaque instruction permet d effectuer

Plus en détail

Tableaux et boucle For

Tableaux et boucle For Tableaux et boucle For Pierre-Alain FOUQUE Département d Informatique École normale supérieure Plan 1 -Tableaux 2 -Boucles for 3 -Paramètres sur la ligne de commande 2 Limite des types de base Définir

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

Les structures de données. Rajae El Ouazzani

Les structures de données. Rajae El Ouazzani Les structures de données Rajae El Ouazzani La récursivité 2 Définition Une procédure ou une fonction est dite récursive si elle fait appel à elle même, directement ou indirectement. 3 Exemple : Réalisation

Plus en détail

INF145 Programmation avancée et langage C MOTS RÉSERVÉS ET INSTRUCTIONS AU PRÉPROCESSEUR

INF145 Programmation avancée et langage C MOTS RÉSERVÉS ET INSTRUCTIONS AU PRÉPROCESSEUR Université du Québec (UQ) École de technologie supérieure Service des enseignements généraux Local B-2500-396-8938 Site Internet : http://www.seg.etsmtl.ca/inf115/ INF145 Programmation avancée et langage

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

Laboratoire MSSMat. Formation Makefiles. GNU Make, niveau débutant. A.-S. Mouronval. Mars 2005

Laboratoire MSSMat. Formation Makefiles. GNU Make, niveau débutant. A.-S. Mouronval. Mars 2005 Laboratoire MSSMat Formation Makefiles GNU Make, niveau débutant A.-S. Mouronval Mars 2005 1 A quoi sert make? Utilitaire permettant d'exécuter des instructions pour construire une application Permet d'optimiser

Plus en détail

Méthodologie de la programmation

Méthodologie de la programmation Méthodologie de la programmation Pablo Rauzy pablo rauzy @ univ-paris8 fr pablo.rauzy.name/teaching/mdlp UFR MITSIC / L1 informatique Séance e Aperçu du langage C : introduction Pablo Rauzy (Paris 8 /

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

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

C Facile. Le langage C. louen@via.ecp.fr. Mardi 15 décembre 2009. Centrale Réseaux. C Facile. Valentin Roussellet (p2010) - louen@via.ecp.

C Facile. Le langage C. louen@via.ecp.fr. Mardi 15 décembre 2009. Centrale Réseaux. C Facile. Valentin Roussellet (p2010) - louen@via.ecp. Le langage C Centrale Réseaux Mardi 15 décembre 2009 Sommaire C quoi? Le C est un langage de programmation créé en 1974, pour écrire le système d exploitation UNIX. Depuis,il est devenu (avec ses variantes),

Plus en détail

Tableaux à deux dimensions

Tableaux à deux dimensions Cours 8 Tableaux à deux dimensions Un tableau à deux dimensions (tableau 2D) est un tableau contenant des lignes et des colonnes comme celui-ci : 4 22 55 2 5 2 4 4 2 24 2 12 Ce tableau à deux dimensions

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

Les fonctions et les procédures en C

Les fonctions et les procédures en C Les fonctions et les procédures en C Séance 6 de l'ue «introduction à la programmation» Bruno Bouzy bruno.bouzy@parisdescartes.fr Fonctions et procédures Fonction, déclaration, définition, utilisation

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

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

Sommaire. 1 - Objectifs...2. 2 - Présentation de la console Enttec...2. 3 - Travail demandé...6. Annexes...9. 1.1 Présentation... 2 1.2 Schéma...

Sommaire. 1 - Objectifs...2. 2 - Présentation de la console Enttec...2. 3 - Travail demandé...6. Annexes...9. 1.1 Présentation... 2 1.2 Schéma... Sommaire 1 - Objectifs...2 1.1 Présentation... 2 1.2 Schéma... 2 2 - Présentation de la console Enttec...2 2.1 Caractéristiques... 2 2.2 Protocoles... 2 2.3 Capture de trame réseau...3 2. Décodage de trame

Plus en détail

Série d exercices N 9 Arbres

Série d exercices N 9 Arbres Série d exercices N 9 Arbres Exercice 1 a) Ecrire une fonction ARBIN creerarbreentiers() qui permet de créer et de renvoyer l arbre d entiers suivant : b) Ecrire une fonction int feuilles(arbin a) qui

Plus en détail

TD 4 - Sockets et Client / Serveur

TD 4 - Sockets et Client / Serveur TD 4 - Sockets et Client / Serveur Exercice 1 Serveur d echo Écrire en Java un serveur TCP d echo (fichier echoserver.java) qui retourne aux clients ce que ces derniers lui émettent. Dans cette première

Plus en détail

Jeu Simon: analyse. La partie est perdue, on a eu une erreur ou un dépassement du temps limite : musique

Jeu Simon: analyse. La partie est perdue, on a eu une erreur ou un dépassement du temps limite : musique Jeu Simon: analyse 1 Algorithme du jeu : Effectuer un tirage de la séquence des couleurs (20 éléments, 3 couleurs) Répéter Afficher la séquence des couleurs et émission des notes associées Répéter Entrée

Plus en détail

Programmation : Exercices

Programmation : Exercices Programmation : Exercices IUT de Villetaneuse R&T 1 ère année Laure Petrucci 6 novembre 2007 1 Premiers programmes Exercice 1.1 : Machine à dessiner On souhaite écrire un programme pour afficher des dessins.

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

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

Partiel QCM - Langage C (LC4)

Partiel QCM - Langage C (LC4) Partiel QCM - Langage C (LC4) 1er avril 2009 Durée: 1h45 - Documents interdits Pour chaque question, il y a exactement une bonne réponse. Le tableau où vous devez répondre est fourni séparément. +1 pour

Plus en détail

0.1 Création d une bibliothèque

0.1 Création d une bibliothèque 0.1 Création d une bibliothèque 1 0.1 Création d une bibliothèque Je vais ici simplement me contenter de reprendre l exemple de l introduction et réécrire le programme cette fois en utilisant une bibliothèque

Plus en détail

GESTION DES FICHIERS. Plan

GESTION DES FICHIERS. Plan Chapitre 10 GESTION DES FICHIERS Objectif: Connaître et manipuler les différentes primitives de gestion de fichier de niveau haut. Pré requis: Les fonction d'entrées sorties Les pointeurs Les structures

Plus en détail

Cours Langage C. Passage de paramètres à la fonction main Pointeur de fonction Allocation dynamique

Cours Langage C. Passage de paramètres à la fonction main Pointeur de fonction Allocation dynamique Cours Langage C Passage de paramètres à la fonction main Pointeur de fonction Allocation dynamique I Passage de paramètres à la fonction main Tout exécutable C doit comporter une fonction main dont le

Plus en détail

TP Qt : Prise en main

TP Qt : Prise en main Université de Strasbourg UFR de Mathématiques et d Informatique Département d Informatique Licence 3 d Informatique IHM Année 2009/2010 TP Qt : Prise en main Objectif Le but de ce tp est une prise en main

Plus en détail

Quelques éléments de compilation en C et makefiles

Quelques éléments de compilation en C et makefiles Quelques éléments de compilation en C et makefiles Guillaume Feuillade 1 Compiler un programme C Le principe de la compilation consiste à passer d un ensemble de fichiers de code à un programme exécutable

Plus en détail

4 Le graphisme (2 nde partie)

4 Le graphisme (2 nde partie) 4 Le graphisme (2 nde partie) 4.1 Valeur de retour de la fonction main () La fonction main peut être déclarée avec une valeur de retour : ou sans: void main () Le choix entre ces deux façons réside dans

Plus en détail

Les structures. Chapitre 3

Les 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é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

TP : commande awk. D'après le cours en ligne de Isabelle Vollant http://www.shellunix.com/awk.html

TP : commande awk. D'après le cours en ligne de Isabelle Vollant http://www.shellunix.com/awk.html TP : commande awk D'après le cours en ligne de Isabelle Vollant http://www.shellunix.com/awk.html Nous reprenons dans ce TP une grande partie du cours de Isabelle Vollant en simplifiant quelques informations.

Plus en détail

PROJET ALGORITHMIQUE ET PROGRAMMATION II

PROJET ALGORITHMIQUE ET PROGRAMMATION II PROJET 1 ALGORITHMIQUE ET PROGRAMMATION II CONTENU DU RAPPORT A RENDRE : o Fiche signalétique du binôme o Listing des différents fichiers sources o CD sources o Il sera tenu compte de la présentation du

Plus en détail

3ETI, Examen [CSC2] Developpement Logiciel en C CPE Lyon

3ETI, Examen [CSC2] Developpement Logiciel en C CPE Lyon 3ETI, Examen [CSC2] Developpement Logiciel en C CPE Lyon 2013-2014 (1ere session) durée 3h Tous documents et calculatrices autorisés. Répondez aux questions sur une copie séparée Le sujet comporte 12 pages

Plus en détail

Entrée et sortie standards (stdin,stdout et cin,cout)

Entrée et sortie standards (stdin,stdout et cin,cout) Chapitre 4 Entrée et sortie standards (stdin,stdout et cin,cout) Pour réaliser les opérations élémentaires d écriture sur l écran ou de lecture des informations du clavier, le C utilise un ensemble de

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

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

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

6. Lecture/écriture formatées et Fichiers. printf / scanf Fichier: Mémoire tampon Accès aux fichiers Modes d'ouverture Lecture / écriture

6. Lecture/écriture formatées et Fichiers. printf / scanf Fichier: Mémoire tampon Accès aux fichiers Modes d'ouverture Lecture / écriture 1 6. Lecture/écriture formatées et Fichiers printf / scanf Fichier: Mémoire tampon Accès aux fichiers Modes d'ouverture Lecture / écriture 2 Références Site du zèro : Programmer en C http://www.siteduzero.com/tutoriel-3-14189-apprenez-a-programmer-en-c.html

Plus en détail

Programmation C++ (débutant)/les tableaux statiques

Programmation C++ (débutant)/les tableaux statiques Programmation C++ (débutant)/les tableaux statiques 1 Programmation C++ (débutant)/les tableaux statiques Le cours du chapitre 6 : les tableaux statiques Les tableaux Une variable entière de type int ne

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

Langage C avancé Utilisation du préprocesseur cpp

Langage C avancé Utilisation du préprocesseur cpp Langage C avancé Utilisation du préprocesseur cpp Samuel KOKH Maison de la Simulation - CEA Saclay samuel.kokh@cea.fr MACS 1 (2013-2014) Institut Galilée S. KOKH (MdlS) Langage C avancé ISPG/MACS 1 2013-2014

Plus en détail

Complément du cours Langage C

Complément du cours Langage C Complément du cours Langage C Licence Fondamentale SMI (semestre 3) Pr. Mouad BEN MAMOUN ben_mamoun@fsr.ac.ma Année universitaire 2013/2014 2013/2014 Pr. Ben Mamoun 1 Chapitre 9 Types structures, unions

Plus en détail

Les processus légers : threads

Les processus légers : threads Les processus légers : threads 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 Les threads Les threads sont des processus

Plus en détail

Pour signifier qu'une classe fille hérite d'une classe mère, on utilise le mot clé extends class fille extends mère

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

Plus en détail

Travaux Pratiques en Dev C++ (1 GIM)

Travaux Pratiques en Dev C++ (1 GIM) Université Sidi Mohammed Ben Abdellah École Supérieure de Technologie de Fès Filière Génie Industriel et Maintenance Travaux Pratiques en Dev C++ (1 GIM) Mr KHATORY TABLE DE MATIERES PREMIERS PAS EN DEV

Plus en détail

1 Hello world. 2 Sorties en C. DUT Informatique M3101 Système S3 2015 / 2016. Travaux Pratiques n o 0 : Rappels de programmation C

1 Hello world. 2 Sorties en C. DUT Informatique M3101 Système S3 2015 / 2016. Travaux Pratiques n o 0 : Rappels de programmation C DUT Informatique 2015 / 2016 Travaux Pratiques n o 0 : Rappels de programmation C Nom(s) : Groupe : Date : Objectifs : renouer avec les notions, la manipulation et l écriture de programmes C, en particulier

Plus en détail