Pointeurs de fonctions

Save this PDF as:
 WORD  PNG  TXT  JPG

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

Download "Pointeurs de fonctions"

Transcription

1 Florence Levé - Université de Picardie Jules Verne 145 Pointeurs de fonctions Parfois utile de passer une fonction comme paramètre d une autre fonction Un pointeur de fonction correspond à l adresse du début du code de la fonction Un pointeur sur une fonction de prototype type fonction (type_1,..., type_n); est de type type (*)(type_1,..., type_n);

2 Florence Levé - Université de Picardie Jules Verne 146 Pointeurs de fonctions Une fonction operateur_binaire prenant en paramètres deux entiers et une fonction de type int, qui prend ellemême 2 entiers en paramètres, sera définie par : int operateur_binaire (int, int, int(*f)(int, int)) Sa déclaration est donnée par int operateur_binaire (int, int, int(*)(int, int)); Pour appeler la fonction operateur_binaire, on utilisera comme troisième paramètre l identificateur de la fonction utilisée.

3 Florence Levé - Université de Picardie Jules Verne 147 Pointeurs de fonctions Par exemple, si somme est une fonction de prototype int somme(int, int); on appelle operateur_binaire pour la fonction somme par l expression : operateur_binaire(a,b,somme); Remarque : on n utilise pas la notation &somme comme paramètre effectif de operateur_binaire

4 Florence Levé - Université de Picardie Jules Verne 148 Pointeurs de fonctions Pour appeler la fonction passée en paramètre dans le corps de la fonction operateur_binaire, on écrit (*f )( a, b). Exemple int operateur_binaire (int a, int b, int (*f) (int, int)) { } return ( (*f ) (a,b) ) ;

5 Florence Levé - Université de Picardie Jules Verne 149 Pointeurs Interprétation de déclarations pouvant paraître complexes int (*(*f [ ] ) ( ) ) ; /*???????????????????/* Algorithme Répéter s il existe * d indirection alors le traiter et l éliminer sinon s il existe [] de tableau alors le traiter et l éliminer sinon s il existe des parenthèses alors les éliminer jusqu à être ramené à un identificateur

6 Florence Levé - Université de Picardie Jules Verne 150 Pointeurs char * f ( ) ; * f ( ) est un char f ( ) un pointeur vers char f une fonction retournant un pointeur vers un char int * f [10] ; *f [10] est un entier f [10] un pointeur vers un entier f un tableau (de 10 éléments) de pointeurs vers un entier

7 Florence Levé - Université de Picardie Jules Verne 151 Pointeurs char (*f ) ( ); (*f ) ( ) est un char (*f ) une fonction qui retourne un char *f une fonction qui retourne un char f un pointeur vers une fonction retournant un char char *( *f ) ( ); *( *f ) ( ) est un char (*f ) ( ) un pointeur vers un char (*f ) une fonction retournant un pointeur vers un char *f une fonction retournant un pointeur vers un char f un pointeur vers une fonction retournant un pointeur vers un char

8 Florence Levé - Université de Picardie Jules Verne 152 Pointeurs static char * c [ ] = { «MOINS», «PLUS», «EGAL»} ; * c [ ] est un char c [ ] pointeur vers char c tableau de pointeurs vers char

9 Florence Levé - Université de Picardie Jules Verne 153 Exercice TABLEAU DE FONCTIONS Ecrivez un programme calfon permettant d obtenir à la console des valeurs des fonctions : sin, cos, exp, log. Exemple : $ calfon sin $ calfon log10 23 log10 : fonction inconnue

10 Florence Levé - Université de Picardie Jules Verne 154 Compilation séparée Modularité Un programme doit être découpé en plusieurs fichiers, même de petites tailles (réutilisabilité, lisibilité, etc.). Chaque composante logique (un module) regroupe les fonctions et types autour d'un même thème. Les modules s'appellent les uns les autres. Si M1 utilise une fonction de M2, il n'a pas besoin du code de la fonction mais juste de sa signature, c'est à dire son nom, le nombre de paramètres, leur ordre et leur type, et le type retourné.

11 Florence Levé - Université de Picardie Jules Verne 155 Compilation séparée Remarque : si le compilateur rencontre un appel à une fonction qu'il ne connaît pas (qui n'a pas été déclarée précédemment), il ne râle pas et considère par défaut que c'est une fonction de type int. Il ne se mettra à râler que si il rencontre plus tard une définition contradictoire pour cette fonction on lui demande de faire avec cette fonction quelque chose qu'on ne peut pas faire avec un int S'il ne trouve nulle part le code de cette fonction, c'est lors de l'édition des liens qu'il râlera.

12 Florence Levé - Université de Picardie Jules Verne 156 Compilation séparée Pour chaque module truc, on fera 2 fichiers fichier entête truc.h. L'interface. Contient la signature de toutes les fonctions exportées et la déclaration des types exportés. fichier truc.c. Le code de toutes les fonctions exportées, déclaration de variables locales, fonctions locales, types locaux. Et contient au début l'inclusion du.h (pour vérifier qu'on raconte bien la même chose partout) Tout module ou programme principal qui a besoin des fonctions du module truc, devra juste inclure le fichier truc.h

13 Florence Levé - Université de Picardie Jules Verne 157 Compilation séparée Exemple : module tab de manipulation de tableaux module tri qui offre plusieurs méthodes de tris de tableaux un programme principal qui veut créer un tableau, le trier par le tri bulle et l'afficher.

14 Florence Levé - Université de Picardie Jules Verne 158 Compilation séparée fichier tab.h /* module de gestion de tableaux */ typedef int *TAB; // type TAB = un tableau void lecture(tab,int); // fonction de lecture d'un tableau de taille donnee //... commentaire sur ce que fait chaque fonction void affichage(tab,int); TAB creation(int); int acces(tab,int);

15 Florence Levé - Université de Picardie Jules Verne 159 Compilation séparée #include «tab.h» fichier tab.c TAB creation(int taille) { malloc... return... } void lecture(tab t,int taille){ int i; for (i=0;i<taille;i++)... }...

16 Florence Levé - Université de Picardie Jules Verne 160 Compilation séparée fichier tri.h fichier tri.c /*module de tris de tableaux*/ #include «tri.h» // pour connaitre le type TAB #include «tab.h» void tri_bulle(tab,int); void tri_rapide(tab,int); void tri_bulle(tab t,int taille){... } void tri_rapide tri_bulle(tab t,int taille){... }

17 Florence Levé - Université de Picardie Jules Verne 161 Compilation séparée #include «tab.h» #include «tri.h» fichier main.c TAB montab; int main( ){ montab=creation(10); lecture(montab,10); tri(montab,10); affichage(montab,10); }

18 Florence Levé - Université de Picardie Jules Verne 162 Compilation séparée Comment relier tout ça? avec tab.c et tab.h, on forme un fichier objet tab.o avec tri.c, tab.h et tri.h, on forme un fichier objet tri.o avec main.c, tri.h et tab.h, on forme un fichier objet main.o On fait l'édition des liens des main.o tri.o et tab.o et on obtient un éxecutable. C'est à dire qu'il faut donner les ordres de compilation : gcc -c tab.c gcc -c tri.c gcc -c main.c gcc tab.o tri.o main.o -o prog

19 Florence Levé - Université de Picardie Jules Verne 163 Compilation séparée - Makefile fichier Makefile MonProg: main.o tab.o tri.o <tab> gcc main.o tab.o tri.o -o MonProg main.o : main.c tab.h tri.h <tab> gcc -c main.c tri.o : tri.c tri.h tab.h <tab> gcc -c tri.c tab.o : tab.c tab.h <tab> gcc -c tab.c Taper make pour l'exécuter.

20 Compilation séparée Florence Levé - Université de Picardie Jules Verne 164 Intérêt : indispensable quand il y a beaucoup de fichiers (plutôt que de retaper à chaque fois tous les ordres de compilation) il ne fait que ce qui est nécessaire : il ne recompile quelque chose que si la dernière compilation est plus ancienne que la dernière modification d'un fichier (c'est pourquoi il est indispensable de mettre tous les.h utilisés).

21 Florence Levé - Université de Picardie Jules Verne 165 Compilation séparée Raccourcis On peut déclarer des variables VAR=machins qu'on utilise ensuite par $(VAR). La maintenance et la mise à jour sont alors plus faciles à gérer. fichier Makefile CC = gcc OBJ = main.o tab.o tri.o MonProg: $(OBJ) $(CC) $(OBJ) -o MonProg main.o : main.c tab.h tri.h tri.o : tri.c tri.h tab.h tab.o : tab.c tab.h

22 Florence Levé - Université de Picardie Jules Verne 166 Compilation séparée Utilisation de macros spéciales : nom de la cible à reconstruire $* nom de la cible sans suffixe $< nom de la dépendance à partir de laquelle on reconstruit la cible $? liste des dépendances plus récentes que la cible

23 Florence Levé - Université de Picardie Jules Verne 167 Compilation séparée On peut rajouter dans le makefile une ligne pour effacer les fichiers objets clean : rm f *.o

24 Florence Levé - Université de Picardie Jules Verne 168 Préprocesseur Qu est-ce que c est? Simple substitution de texte Augmente la lisibilité du code source Augmente la vitesse d exécution du programme Le preprocessing intervient avant la phase de compilation Directives Une directive au préprocesseur commence toujours par # #include, #define, #ifdef Les directives sont effectives sur tout le fichier. Remplacement des directives de précompilation par du code en C (compréhensible par le compilateur)

25 Florence Levé - Université de Picardie Jules Verne 169 Macros Définies par la directive #define Deux formes: Simple remplacement d une chaîne de caractère. Remplacement de la chaîne et substitution d argument. Une macro peut être définie sur plusieurs lignes (retour chariot)

26 Florence Levé - Université de Picardie Jules Verne 170 Macro simple #define IDENTIFIANT chaîne chaîne est une séquence de caractères Toute occurrence de IDENTIFIANT dans le texte sera remplacé par chaîne Exemple : #define PI! ! Remplacera durant la phase de préprocessing toutes les occurrences de la chaîne «PI» dans le fichier C par la chaîne « ». Autre forme de déclaration de constantes

27 Florence Levé - Université de Picardie Jules Verne 171 Macro simple On peut définir les variables de précompilation à l'appel de l'enchaîneur de passes option Dnom=valeur Le préprocesseur changera les occurrences de la variable nom par la valeur valeur, comme si la constante de précompilation nom était définie par la directive #define nom valeur.

28 Florence Levé - Université de Picardie Jules Verne 172 Macro avec arguments (Macroinstruction) Syntaxe #define <chaîne1>(<liste paramètres>) <chaîne2>! (pas d espace entre l identifiant et la parenthèse)!! Exemple Macro qui incrémente une variable #define inc(x) x++! Toute occurrence de «inc(<variable>)» sera respectivement remplacée par <variable>++ durant la phase de précompilation (indépendamment de son type)

29 Florence Levé - Université de Picardie Jules Verne 173 Macro à arguments multiples Code original: #define MIN(X,Y) ( (X)<(Y)? (X) : (Y) ). MIN(a,b); Code intermédiaire:. ( (a) < (b)? (a) : (b) )

30 Florence Levé - Université de Picardie Jules Verne 174 Macros prédéfinies Dans stdio.h #define getchar() getc(stdin) #define putchar(c) putc(c,stdout)

31 Florence Levé - Université de Picardie Jules Verne 175 Problèmes courants Code original: #define SQR(X) X*X SQR(a+1); Code intermédiaire: a+1*a+1; //ce qui est égal à a+(1*a)+1 Solution: parenthéser: #define SQR(X) (X)*(X)

32 Florence Levé - Université de Picardie Jules Verne 176 Les macros ne sont pas des fonctions Code original: #define SWAP(X,Y) {int temp; temp=x; X=Y; Y=temp;} void main(int){ int a=3, b=4; SWAP(a,b); } Code intermédiaire: void main(void){ int a=3,b=4; {int temp; temp=a; a=b; b=temp;} }

33 Florence Levé - Université de Picardie Jules Verne 177 Macro prédéfinies FILE : nom du fichier source courant LINE : numéro de ligne courant DATE : date de compilation du fichier courant TIME : heure de compilation du fichier courant printf(``%s a été compilé le %s\n``, FILE, DATE );

34 Florence Levé - Université de Picardie Jules Verne 178 Opérateurs de Macro # permet de convertir l argument en chaîne de caractères #define MSG(F) printf(#f) MSG(test mess); //devient printf(«test mess»); ## permet de concaténer #define ERR(X,Y) printf(x ## Y) ERR(``err: ``,``une erreur``); //devient printf(``err: une erreur``);

35 Florence Levé - Université de Picardie Jules Verne 179 Dédéfinir et redéfinir des macros Il n est pas permis de redéfinir des macros, sauf si elles ont été dédéfinies par #undef au préalable. #undef est ignoré si l identifiant n a pas été défini #undef peut dédéfinir des macro prédéfinies!!!!

36 Florence Levé - Université de Picardie Jules Verne 180 Inclure des fichiers On inclut des fichiers textes par #include Le texte du fichier est alors recopié à cet endroit. #include <stdio.h> cherche dans le chemin standard le fichier stdio.h #include ``monfichier.h`` cherche le fichier monfichier.h dans le répertoire courant.

37 Florence Levé - Université de Picardie Jules Verne 181 Exercices Écrire une macro qui calcule le maximum de deux nombres et écrire un programme de test qui l'utilise

38 Florence Levé - Université de Picardie Jules Verne 182 Solution #include <stdio.h> /* Definition de la macro */ #define max(x,y) (((x) > (y))? (x) : (y)) /* Le programme de test */ int main ( ) { int n1, n2; /* Deux nombres a fournir par l'utilisateur */ /* Demande et lecture des deux nombres */ printf("introduire n1 : "); scanf("%d", &n1); printf("introduire n2 : "); scanf("%d", &n2); /* Calcul du maximum et affichage du resultat */ printf("max(%d, %d) = %d\n", n1, n2, max(n1, n2)); }

39 Florence Levé - Université de Picardie Jules Verne 183 Inclure des fichiers Possible de demander au pré-processeur d'ajouter d'autres catalogues à sa recherche option de compilation -Inom_du_catalogue. Cette option peut être utilisée plusieurs fois de manière à spécifier plusieurs catalogues de recherche. Les fichiers inclus peuvent contenir d'autres inclusions de fichiers. Ce processus récursif est parfois limité à quelques niveaux d'inclusion.

40 Florence Levé - Université de Picardie Jules Verne 184 Inclure des fichiers Si le nom du fichier est entre guillemets, le préprocesseur cherche le fichier : dans le catalogue courant, puis dans les catalogues spécifiés par les options -I. Si le nom du fichier est entre < >, le préprocesseur cherche le fichier : dans les catalogues spécifiés par les options -I, puis dans le catalogue par défaut du compilateur.

41 Florence Levé - Université de Picardie Jules Verne 185 Conséquence des inclusions #include <stdio.h> typedef int *p_int; #include ``prog1.h`` int main(void){ } Prog1.c pourra alors utiliser les fonctions de la bibliothèque stdio.h

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

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

cours 6 - compilation séparée, classes de stockage et makefile

cours 6 - compilation séparée, classes de stockage et makefile cours 6 - compilation séparée, classes de stockage et makefile G. Bianchi, G. Blin, A. Bugeau, S. Gueorguieva, R. Uricaru 2015-2016 Programmation 1 - uf-info.ue.prog1@diff.u-bordeaux.fr la programmation

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

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

Cours Langage C/C++ Programmation modulaire

Cours Langage C/C++ Programmation modulaire Cours Langage C/C++ Programmation modulaire Thierry Vaira BTS IRIS Avignon tvaira@free.fr «v0.1 Rappel Programmation modulaire (1/2) Le découpage d'un programme en sous-programmes est appelée programmation

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

Seance 2: En respectant la méthode de programmation par contrat, implémentez les autres fonctions de jeu.

Seance 2: En respectant la méthode de programmation par contrat, implémentez les autres fonctions de jeu. Seance 2: Complétion du code de jeu. (durée max: 2h) Mot clé const et pointeurs: En respectant la méthode de programmation par contrat, implémentez les autres fonctions de jeu. Implémentez jeu_recupere_piece

Plus en détail

1. Eléments de base du langage C

1. Eléments de base du langage C 1 1. Eléments de base du langage C Généralités Programme et sous-programme Fonction C Structure d un programme C Vocabulaire de base et syntaxe Exemples 2 Généralités Crée en 1972 par D. Ritchie pour écrire

Plus en détail

Compilation séparée. ENSIIE: Programmation avancée, Compilation séparée, Modularité, Spécifications algébriques 1

Compilation séparée. ENSIIE: Programmation avancée, Compilation séparée, Modularité, Spécifications algébriques 1 Compilation séparée ENSIIE: Programmation avancée, Compilation séparée, Modularité, Spécifications algébriques 1 Modularité GCC : 4 millions de lignes de code Noyau Linux : 12 millions de lignes de code

Plus en détail

Compilation séparée. Compilation séparée. ENSIIE: Programmation avancée, Compilation séparée, Modularité, Spécifications algébriques 1

Compilation séparée. Compilation séparée. ENSIIE: Programmation avancée, Compilation séparée, Modularité, Spécifications algébriques 1 Compilation séparée Compilation séparée ENSIIE: Programmation avancée, Compilation séparée, Modularité, Spécifications algébriques 1 Compilation séparée Modularité GCC : 4 millions de lignes de code Noyau

Plus en détail

Compilation avec Make

Compilation avec Make Compilation avec Make Laurent Réveillère Enseirb-Matmeca / IPB Département Télécommunications Laurent.reveillere@ipb.fr http://http://reveille.vvv.enseirb-matmeca.fr/ Objectifs Automatiser la reconstruction

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

Initiation au C cours n 9

Initiation au C cours n 9 Initiation au C cours n 9 Antoine Miné École normale supérieure 26 avril 2007 Plan du cours compilation séparée, modularité, bibliothèques.a et.so, recompilation automatique avec make. Déroulement de la

Plus en détail

Environnement de développement / Projet de programmation 1 (J1INPW01) Compilation

Environnement de développement / Projet de programmation 1 (J1INPW01) Compilation Environnement de développement / Projet de programmation 1 (J1INPW01) Compilation Plan gcc (compilation et compilation séparée) Make (Makefile) Makefile générique 2 Compilation simple #include

Plus en détail

Introduction au langage C

Introduction au langage C Organisation du cours Introduction au langage C Premier cours Notions générales Aurélien Max aurelien.max@limsi.fr 12 séances de cours de 1h: mercredi 16-17h, salle A203 12 séances de TD de 1h: mercredi

Plus en détail

Ecrire un Makefile, sans douleur et en quelques leçons.

Ecrire un Makefile, sans douleur et en quelques leçons. Ecrire un Makefile, sans douleur et en quelques leçons. M. Billaud Département Informatique Institut Universitaire de Technologie Université Bordeaux 1 Mai 2010 Résumé Ce document montre comment écrire

Plus en détail

Formation Unix/Linux (9) Introduction à la programmation C sous Unix

Formation Unix/Linux (9) Introduction à la programmation C sous Unix Formation Unix/Linux (9) Introduction à la programmation C sous Unix Olivier BOEBION Mars 2004 1 Le langage C Introduire un langage de développement dans des travaux pratiques sur un système d exploitation

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

Utilisation de make. Chapitre 1. 1.1 make : pour quoi faire? 1.2 Introduction aux makefiles

Utilisation de make. Chapitre 1. 1.1 make : pour quoi faire? 1.2 Introduction aux makefiles Chapitre 1 Utilisation de make 1.1 make : pour quoi faire? make est un programme qui détermine automatiquement quelles parties d un programme doivent être recompilées, et exécute les commandes nécessaires

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

Licence STPI Semestre 3 - Examen de Validation de Module - Janvier 2006 ULSI301 - LANGAGE C

Licence STPI Semestre 3 - Examen de Validation de Module - Janvier 2006 ULSI301 - LANGAGE C Licence STPI Semestre 3 - Examen de Validation de Module - Janvier 2006 ULSI301 - LANGAGE C Durée : 2h. - Documents et Calculatrices autorisés. Toutes les réponses doivent être justifiées - Les exercices

Plus en détail

Notes sur la compilation séparée

Notes sur la compilation séparée Annexe B Notes sur la compilation séparée Ce document est probablement imparfait, mais il devrait déjà donner une introduction raisonnable au sujet traité... B.1 Introduction La compilation séparée est

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

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

Cours d Analyse, Algorithmique Elements de programmation

Cours d Analyse, Algorithmique Elements de programmation 1 de 33 Cours d Analyse, Algorithmique Elements de programmation Florent Hivert Mél : Florent.Hivert@lri.fr Adresse universelle : http://www.lri.fr/ hivert 2 de 33 Données et instructions Un programme

Plus en détail

Langage C. Chapitre 2. 2.1 Le langage C, un langage non interprété. 2.1.1 L écriture du programme. 2.1.2 La compilation

Langage C. Chapitre 2. 2.1 Le langage C, un langage non interprété. 2.1.1 L écriture du programme. 2.1.2 La compilation Chapitre 2 Langage C 2.1 Le langage C, un langage non interprété Le C est un langage de programmation comme il en existe beaucoup d autres (C++, Fortran, Python, Matlab, IDL, ADA...). Il existe deux grandes

Plus en détail

Concevoir un Makefile. Vincent Loechner (original : Nicolas Zin, http://www.linux.efrei.fr/)

Concevoir un Makefile. Vincent Loechner (original : Nicolas Zin, http://www.linux.efrei.fr/) Concevoir un Makefile Vincent Loechner (original : Nicolas Zin, http://www.linux.efrei.fr/) 17 novembre 2003 Table des matières 1 Introduction 2 2 Création d un makefile 3 2.1 Simple Makefile............................

Plus en détail

Plan. Tableaux. Utilité. Définition. Exemples. Déclaration d un tableau

Plan. Tableaux. Utilité. Définition. Exemples. Déclaration d un tableau Plan Tableaux Université de Nice - Sophia Antipolis Richard Grin Version 1.0.4 25/11/10 Définition Déclaration d un tableau Création d un tableau Utilisation d un dun tableau Tableau des paramètres de

Plus en détail

UE1 - Langage C Fiche TP1

UE1 - Langage C Fiche TP1 1 UE1 - Langage C Fiche TP1 Objectifs 1. Connaître quelques commandes linux 2. Savoir manipuler les outils de compilation tels que gcc, make 3. Ecrire des algorithmes, les coder en C, et les exécuter 1.

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

Objectifs de ce cours. Introduction au langage C - Cours 4. Procédures. Exemple de procédure. Analyse de problème.

Objectifs de ce cours. Introduction au langage C - Cours 4. Procédures. Exemple de procédure. Analyse de problème. 1/30 Objectif de ce cours 2/30 Objectifs de ce cours Introduction au langage C - Cours 4 Girardot/Roelens Septembre 2013 Analyse de problème I décomposer un traitement complexe en traitements simples Concepts

Plus en détail

Bases de programmation. Cours 5. Structurer les données

Bases de programmation. Cours 5. Structurer les données Bases de programmation. Cours 5. Structurer les données Pierre Boudes 1 er décembre 2014 This work is licensed under the Creative Commons Attribution-NonCommercial-ShareAlike 3.0 License. Types char et

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

renforcer le contrôle de type :

renforcer le contrôle de type : renforcer le contrôle de type : définitions, prototypes de fonctions surcharge références conversions de void * préférer le compilateur au préprocesseur considérer les entrées/sorties opérations abstraites

Plus en détail

Atelier 0: Initiation aux outils de développement C sous Linux

Atelier 0: Initiation aux outils de développement C sous Linux 1)Objectifs: Atelier 0: Initiation aux outils de développement C sous Linux S'initier à l'utilisation de quelques outils de développement avec le langage C sous Linux. Développer en C sous Linux à partir

Plus en détail

L utilitaire "make" et son inséparable Makefile

L utilitaire make et son inséparable Makefile L utilitaire "make" et son inséparable Makefile Compilation et exécution Programme source Analyse lexicale (scaning) Optimisation du code Programme abstrait (optimisé) Génération du code Séquence d unités

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

Objectifs. Arguments de main() Précompilateur. Compilation séparée. Makefiles

Objectifs. Arguments de main() Précompilateur. Compilation séparée. Makefiles du cours d aujourd hui Programmation «orientée système» LANGAGE C COMPILATION passer des arguments à son programme directives de précompilation compilation Makefile Laboratoire d Intelligence Artificielle

Plus en détail

Ecriture d un Makefile

Ecriture d un Makefile Ecriture d un Makefile ENSIMAG 1A Année scolaire 2008 2009 Un Makefile est un fichier, utilisé par le programme make, regroupant une série de commandes permettant d exécuter un ensemble d actions, typiquement

Plus en détail

Les logins et mots de passe sont les mêmes que l année dernière.

Les logins et mots de passe sont les mêmes que l année dernière. Travaux pratiques 01 2015 2016 1 Poste de travail 1.1 Connection Les logins et mots de passe sont les mêmes que l année dernière. 1.2 Le terminal Pour ouvrir un terminal, allez dans le menu en bas à gauche

Plus en détail

Les chaînes de caractères

Les chaînes de caractères Les chaînes de caractères Dans un programme informatique, les chaînes de caractères servent à stocker les informations non numériques comme par exemple une liste de nom de personne ou des adresses. Il

Plus en détail

Compilation séparée avec make

Compilation séparée avec make ENSTA ParisTech École nationale supérieure de techniques avancées Compilation séparée avec make Cours IN201 Systèmes d exploitation Marc Baudoin La compilation séparée est

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

Langage C/C++ TD 3-4 : Création dynamique d objets. Hubert Godfroy. 27 novembre 2014

Langage C/C++ TD 3-4 : Création dynamique d objets. Hubert Godfroy. 27 novembre 2014 Langage C/C++ TD 3-4 : Création dynamique d objets Hubert Godfroy 7 novembre 014 1 Tableaux Question 1 : Écrire une fonction prenant un paramètre n et créant un tableau de taille n (contenant des entiers).

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

Les outils de développement en langage C++

Les outils de développement en langage C++ Les outils de développement en langage C++ Sommaire Les étapes de réalisation d'un exécutable Le pré processeur La création d'un exécutable Les étapes de réalisation d'un exécutable Traitement des fichiers

Plus en détail

DE L ALGORITHME AU PROGRAMME INTRO AU LANGAGE C 51

DE 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étail

Travaux pratiques. Compression en codage de Huffman. 1.3. Organisation d un projet de programmation

Travaux 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étail

# Zone où typiquement seront placées des déclarations de variables et de règles # (voir plus tard)

# Zone où typiquement seront placées des déclarations de variables et de règles # (voir plus tard) UNIVERSITÉ DE NICE SOPHIA ANTIPOLIS UFR FACULTÉ DES SCIENCES Parc Valrose BP 71 F 06108 NICE Cedex 2 Licence 3 d Informatique Environnement de Programmation 2005-2006 Philippe Collet Séance de TP n 02

Plus en détail

Cours d initiation à la programmation en C++ Johann Cuenin

Cours d initiation à la programmation en C++ Johann Cuenin Cours d initiation à la programmation en C++ Johann Cuenin 11 octobre 2014 2 Table des matières 1 Introduction 5 2 Bases de la programmation en C++ 7 3 Les types composés 9 3.1 Les tableaux.............................

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

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

Cours Unix 5. La commande awk. 1. La commande awk. 2. La commande make. Plan du cours 5

Cours Unix 5. La commande awk. 1. La commande awk. 2. La commande make. Plan du cours 5 Cours Unix 5 Michel Mauny La commande awk ETGL Le cours 4 est disponible sur http://quincy.inria.fr/courses/unix/ Plan du cours 5 La commande awk [La commande awk 2] Similaire à sed, mais plus puissant.

Plus en détail

Cycle de vie d un programme

Cycle de vie d un programme Cycle de vie d un programme Ensimag 1A - Préparation au Projet C Année scolaire 2009 2010 Les objectifs de cette séance sont : de comprendre les différentes étapes de la chaîne de compilation d un programme

Plus en détail

MEUTER Cédric / LEVY Eythan. Université Libre de Bruxelles 23/09/2005

MEUTER Cédric / LEVY Eythan. Université Libre de Bruxelles 23/09/2005 Développement en C sous LINUX MEUTER Cédric / LEVY Eythan Université Libre de Bruxelles 23/09/2005 Développement en C sous LINUX p. 1 Comment écrire son programme? Principaux éditeurs : XEmacs Emacs vi

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

Chapitre 3 : Pointeurs et références

Chapitre 3 : Pointeurs et références p. 1/18 Chapitre 3 : Pointeurs et références Notion de pointeur L adresse d une variable est une valeur. On peut donc la stocker dans une variable. Un pointeur est une variable qui contient l adresse d

Plus en détail

Une introduction au langage C++ Marc Jachym, Lurpa

Une introduction au langage C++ Marc Jachym, Lurpa Une introduction au langage C++ Marc Jachym, Lurpa Janvier 2008 À l origine, le langage C Langage procédural créé dans les années 1970 aux laboratoires Bell (ATT : télécoms américains) en vue d écrire

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

Algorithmique et Langage C

Algorithmique et Langage C Algorithmique et Langage C www.polytech.unice.fr/~vg/fr/enseignement/xidian Granet Vincent - vg@unice.fr Xi an - Octobre 2015 - Avril 2016 Sommaire Sommaire 1 Sommaire 2 Bibliographie 3 Introduction 4

Plus en détail

TD1. La programmation en C sous Unix. ASR4 C sous Unix

TD1. La programmation en C sous Unix. ASR4 C sous Unix ASR4 C sous Unix TD1 La programmation en C sous Unix I U T d ' A m i e n s, d é p a r t e m e n t I n f o r m a t i q u e a n n é e u n i v e r s i t a i r e 2 0 1 0 / 2 0 1 1 A S R 4 Plan A. Préparation

Plus en détail

TD1 : Scripts bash. I. Courrier gagnant. II. Opacification de texte. Rappels

TD1 : Scripts bash. I. Courrier gagnant. II. Opacification de texte. Rappels TD1 : Scripts bash I. Courrier gagnant 1) Écrire un script couga.sh qui lit au clavier un nom, prénom, numéro de rue, nom de la rue, code postal et ville, puis affiche sur la sortie standard l adresse

Plus en détail

Programmation impérative

Programmation 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étail

1 Librairies sous Linux avec GCC... 1. 1.1 Projet multi-fichiers simple... 1. 1.2 Projet multi-fichiers avec une librairie statique...

1 Librairies sous Linux avec GCC... 1. 1.1 Projet multi-fichiers simple... 1. 1.2 Projet multi-fichiers avec une librairie statique... 1 Librairies sous Linux avec GCC... 1 1.1 Projet multi-fichiers simple... 1 1.2 Projet multi-fichiers avec une librairie statique... 2 1.3 Création d une librairie dynamique... 2 1.4 Projet multi-fichiers

Plus en détail

INF601 : Algorithme et Structure de données. Avant propos

INF601 : Algorithme et Structure de données. Avant propos Avant propos Cours = Introduction aux Types de Données Abstraits (TDA) Chaque TDA est structuré en un ensemble de fichiers Compilation séparée pour faire les programmes Outils : make en C ant en java...

Plus en détail

Algorithmique et Programmation, IMA

Algorithmique et Programmation, IMA Algorithmique et Programmation, IMA Cours 2 : C Premier Niveau / Algorithmique Université Lille 1 - Polytech Lille Notations, identificateurs Variables et Types de base Expressions Constantes Instructions

Plus en détail

Gestion des dépendances. Exemple : # toute ligne qui commence par " # " est un commentaire

Gestion des dépendances. Exemple : # toute ligne qui commence par  #  est un commentaire Gestion des dépendances Exemple : # toute ligne qui commence par " # " est un commentaire # gestion des dépendances # conversion dépend de conversion.c de sorties.c et de entrees.c conversion : conversion.o

Plus en détail

Algorithmique et Programmation, IMA

Algorithmique et Programmation, IMA Algorithmique et Programmation, IMA Cours 3 : Actions, Procédures Université Lille 1 - Polytech Lille Conception Structurée Descendante Les Fonctions Les Actions / les Procédures Résumé Conception Structurée

Plus en détail

Guide pour la conception d'une application en C

Guide pour la conception d'une application en C Guide pour la conception d'une application en C Ph. Preux DESS IMST, ULCO Novembre 1999 1 Principes généraux Une application informatique, dès qu'elle dépasse une centaine de lignes de code, doit impérativement

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

Le langage C. Séance n 4

Le langage C. Séance n 4 Université Paris-Sud 11 Institut de Formation des Ingénieurs Remise à niveau INFORMATIQUE Année 2007-2008 Travaux pratiques d informatique Le langage C Séance n 4 But : Vous devez maîtriser à la fin de

Plus en détail

TP1 - Introduction au langage C

TP1 - Introduction au langage C ENS Lyon L-Info PROJ1 2014-2015 TP1 - Introduction au langage C Sujet à terminer pour le dimanche 20 à 2h59, sous forme d une archive.zip contenant votre code source, par email à aurelien.cavelan@ens-lyon.fr.

Plus en détail

3 Lien entre pointeurs et tableaux.

3 Lien entre pointeurs et tableaux. programme sont dit dynamiques. On se limite ici aux tableaux statiques à une seule dimension, analogue aux vecteurs manipulés en mathématiques. Ils se déclarent sous la forme : type_d_élément variable_tableau[taille];

Plus en détail

TP Compilation Analyse lexicale

TP Compilation Analyse lexicale TP Compilation Analyse lexicale Eric Ramat ramat@lisic.univ-littoral.fr 9 mai 2014 Durée : 6 heures 1 Introduction Le but de cet TP est de vous donner les bases nécessaires afin de pouvoir écrire votre

Plus en détail

Organisation des données et structures de stockage

Organisation des données et structures de stockage ING2 - ING3 Nvx 2009-2010 Organisation des données et structures de stockage I. Stockage de l information en C Ce chapitre rappelle brièvement et complète certaines notions de base vues en première année

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

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

Processus de compilation Préprocesseur Compilation Assemblage Edition de liens. ASR Période 2. Sylvain Jubertie. Département Informatique IUT Orléans

Processus de compilation Préprocesseur Compilation Assemblage Edition de liens. ASR Période 2. Sylvain Jubertie. Département Informatique IUT Orléans ASR Période 2 Sylvain Jubertie Département Informatique IUT Orléans 1 Processus de compilation 2 Préprocesseur 3 Compilation 4 Assemblage 5 Edition de liens Prérequis Prérequis langage C langage assembleur

Plus en détail

I. Introduction aux fonctions : les fonctions standards

I. Introduction aux fonctions : les fonctions standards Chapitre 3 : Les fonctions en C++ I. Introduction aux fonctions : les fonctions standards A. Notion de Fonction Imaginons que dans un programme, vous ayez besoin de calculer une racine carrée. Rappelons

Plus en détail

Le langage C++ est un langage de programmation puissant, polyvalent, on serait presque tenté de dire universel, massivement utilisé dans l'industrie

Le langage C++ est un langage de programmation puissant, polyvalent, on serait presque tenté de dire universel, massivement utilisé dans l'industrie Chapitre I : Les bases du C++ Le langage C++ est un langage de programmation puissant, polyvalent, on serait presque tenté de dire universel, massivement utilisé dans l'industrie du logiciel, et ce depuis

Plus en détail

Licence Bio Informatique Année 2004-2005. Premiers pas. Exercice 1 Hello World parce qu il faut bien commencer par quelque chose...

Licence Bio Informatique Année 2004-2005. Premiers pas. Exercice 1 Hello World parce qu il faut bien commencer par quelque chose... Université Paris 7 Programmation Objet Licence Bio Informatique Année 2004-2005 TD n 1 - Correction Premiers pas Exercice 1 Hello World parce qu il faut bien commencer par quelque chose... 1. Enregistrez

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

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

Compilateurs : Analyse lexicale. Vous êtes ici 2. Analyse lexicale 4. Matthieu Amiguet. En entrée d un compilateur, on a généralement un fichier

Compilateurs : Analyse lexicale. Vous êtes ici 2. Analyse lexicale 4. Matthieu Amiguet. En entrée d un compilateur, on a généralement un fichier Compilateurs : Matthieu Amiguet 2009 2010 Vous êtes ici 2 Partie Avant Analyse syntaxique Analyse sémantique Arbre syntaxique abstrait (AST) Partie Arrière Optimisation de l AST Génération de code Optimisation

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

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

Algorithmie ISI301 TP 1 : Python et premiers algorithmes

Algorithmie ISI301 TP 1 : Python et premiers algorithmes Algorithmie ISI301 TP 1 : Python et premiers algorithmes 1 Python : apprentissage Pour avoir une vision plus large des différentes possibilités du langage Python, nous ne pouvons que vous conseiller d

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

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

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

Initiation à la programmation en Python

Initiation à la programmation en Python I-onventions Initiation à la programmation en Python Une commande Python sera écrite en caractère gras. Exemples : print("bonjour") max=input("nombre maximum autorisé :") Le résultat de l'exécution d'un

Plus en détail

TD 5 LES POINTEURS. Définition: Pointeur

TD 5 LES POINTEURS. Définition: Pointeur TD 5 LES POINTEURS d'après le site de F. Faber http://www.ltam.lu/tutoriel_ansi_c Définition: Pointeur Un pointeur est une variable spéciale qui peut contenir l'adresse d'une autre variable. En C, chaque

Plus en détail

Présentation du langage et premières fonctions

Présentation du langage et premières fonctions 1 Présentation de l interface logicielle Si les langages de haut niveau sont nombreux, nous allons travaillé cette année avec le langage Python, un langage de programmation très en vue sur internet en

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

TP introductif de pratique du C

TP introductif de pratique du C Licence d informatique Module de Pratique du C TP introductif de pratique du C Philippe MARQUET Révision d octobre 2007 Ce premier TP introductif à la programmation en C va vous familiariser avec : la

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

AP2 - programmation objet en C++ Semestre 2, année 2009-2010. Février 2010

AP2 - programmation objet en C++ Semestre 2, année 2009-2010. Février 2010 Makefile / makedepend AP2 - programmation objet en C++ Semestre 2, année 2009-2010 Département d informatique IUT Bordeaux 1 Février 2010 1 / 1 Le projet Situation : écrire un projet de simulation de courses

Plus en détail

Constat. Programmation Modulaire. Génie Logiciel. Difficulté de gérer un logiciel de grande ampleur (>> 10 000 lignes de code)

Constat. Programmation Modulaire. Génie Logiciel. Difficulté de gérer un logiciel de grande ampleur (>> 10 000 lignes de code) Constat Difficulté de gérer un logiciel de grande ampleur (>> 10 000 lignes de code) répartition du travail entre plusieurs personnes temps de compilation maintenance du code réutilisation du code Programmation

Plus en détail

1 Notions de base 1.1 Structure d'un programme

1 Notions de base 1.1 Structure d'un programme 1 Notions de base 1.1 Structure d'un programme Le langage C++ contient le langage C : tout programme écrit en C à la norme ANSI doit pouvoir être compilé par un compilateur C++. C++ fait la diérence entre

Plus en détail