Programmation en langage C Eléments de syntaxe

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

Download "Programmation en langage C Eléments de syntaxe"

Transcription

1 Programmation en langage C Eléments de syntaxe Université Paul Sabatier IUP Systèmes Intelligents L2 Module Informatique de base 2 Initiation à la programmation en langage C Isabelle Ferrané

2 SOMMAIRE I- Concepts fondamentaux du Langage C... 4 I-1. Le jeu de caractères... 4 I-2. Identificateurs et mots clés... 4 I-3. Les types de données... 4 I-3.1. Le type entier : int... 5 I-3.2. Le type caractère : char... 5 I-3.3. Les types flottants : float et double... 5 I-4. Les constantes ou littéraux... 6 I-4.1. Les valeurs entières... 6 I-4.2. Les valeurs flottantes... 6 I-4.3. Les caractères... 6 I-4.4. Les chaînes de caractères... 7 I-5. Les variables et les tableaux... 7 I-5.1. Déclaration de variable simple ou de tableau... 8 I-5.2. Initialisation de variable simple ou de tableau... 9 I-6. Les expressions I-6.1. Expressions et opérateurs arithmétiques I-6.2. Expressions et opérateurs relationnels I-6.3. Expressions et opérateurs logiques I-6.4. Opérateurs d'affectation I-6.5. Priorité des opérateurs I-6.6. Opérateurs pour la manipulation de données binaires I-7. Les instructions I-7.1. Instructions simples I-7.2. Instructions composées ou bloc d'instructions I-7.3. Instructions de contrôle II-. Structure d'un programme en langage C II-1. Les directives II-1.1. Inclusion de fichiers II-1.2. Définition de constantes symboliques II-1.3. Compilation conditionnelle II-2. Les déclarations II-3. Les définitions de données II-4. Les définitions de fonctions II-5. La fonction principale : main III. Les bibliothèques de fonctions standards III-1. Utilisation des fonctions standards III-2. La bibliothèque de fonctions standard stdio.h III-2.1 Les entrées-sorties de caractères III-2.2 Les entrées-sorties de chaînes de caractères III-2.3 Les entrées-sorties formatées III-2.4 Les Entrées-Sorties dans un fichier III-3 Autres bibliothèques et fonctions standards Informatique Générale Langage C 2 Isabelle Ferrané

3 III.3.1. Fichier math.h : Fonctions mathématiques III.3.2. Fichier string.h : Manipulation de chaînes de caractères III.3.3. Fichier ctype.h : Fonctions testant la nature d'un caractère III.3.4. Fichier stdlib.h III.3.5. Autres bibliothèques à connaître IV- Bibliographie Informatique Générale Langage C 3 Isabelle Ferrané

4 I- Concepts fondamentaux du Langage C I-1. Le jeu de caractères Lettres : Chiffres : 0,1,...,9 a,..., z, A,..., Z Caractères spéciaux :! + - * / % < > ( ) { } [ ] ~ # = ;, : ^ \ ' ". & _? espace Commentaires : /* ceci est un commentaire */ I-2. Identificateurs et mots clés Identificateur : suite de caractères alphanumériques incluant éventuellement le blanc souligné et commençant obligatoirement par une lettre (ex : var1, id_var). Mots-clés : mots réservés qui ont une signification prédéfinie en C et qui ne peuvent pas être utilisés comme identificateur. auto break case char const continue default do double else enum extern float for goto if int long register return short signed sizeof static struct switch typedef union unsigned void volatile while I-3. Les types de données Type : définit un domaine de validité de données (valeurs et opérations possibles). Il se caractérise par une représentation mémoire spécifique dont la taille dépend du compilateur. 4 types scalaires prédéfinis : int, char, float et double REMARQUES : (1) Le type booléen n'existe pas en C. La valeur de vérité FAUX est représentée par la valeur numérique 0 et VRAI par 1 (ou toute valeur différente de 0). Informatique Générale Langage C 4 Isabelle Ferrané

5 (2) Le type void est un type prédéfini qui a la particularité de ne pas avoir de taille. Il est utilisé généralement pour indiquer l'absence de données (cf. II.4. définition de fonctions). I-3.1. Le type entier : int Représentation mémoire d'une valeur entière : 2 ou 4 octets Intervalle des valeurs entières (sur 2 octets) Spécificateurs de type : short et long modifient la taille de la représentation mémoire d'un entier tout vérifiant l'inégalité suivante sizeof(short) sizeof(int) sizeof(long) REMARQUE : l'opérateur sizeof appliqué à un type renvoie le nombre d'octets occupés par toute valeur appartenant à ce type. unsigned la taille de la représentation mémoire n'est pas modifiée, mais le bit de signe est utilisé comme un chiffre significatif. sur 2 octets : int unsigned int REMARQUE : le spécificateur unsigned peut être combiné avec short et long. I-3.2. Le type caractère : char Représentation mémoire d'un caractère : 1 octet Chaque donnée de type caractère a un équivalent entier qui correspond au code ASCII du caractère. Intervalle des valeurs des codes ASCII : ou I-3.3. Les types flottants : float et double Représentation mémoire d'un nombre flottant : 4 octets (soit 24 bits pour la mantisse et 8 pour la partie exposant) Représentation d'un nombre flottant double précision : 8 octets Informatique Générale Langage C 5 Isabelle Ferrané

6 I-4. Les constantes ou littéraux I-4.1. Les valeurs entières 3 notations possibles : décimale (base 10 : 0..9) ex : 15 octale (base 8 : 0..7) ex : 017 hexadécimale (base 16 : 0..9,A..F) ex : 0xF ou 0XF Notation avec spécificateurs de type : short int ex : 15 long int ex : 15L unsigned int ex : 15U ou 017U unsigned long int ex : 15UL ou 0xFUL REMARQUE : avec les spécificateurs de type, le mot-clé int peut être omis. I-4.2. Les valeurs flottantes Elles contiennent un point décimal et/ou un exposant. Exemple : I-4.3. Les caractères 12.3, 123E-1, 1.23E1 Notation classique : un caractère est exprimé entre quotes (' ') ou bien représenté par son code ASCII, ici entre parenthèse. Exemple : 'A' (65) '$' (36) ' ' (32) caractère espace Notation symbolique pour les caractères non visualisables : sonnerie \a retour arrière \b tabulation horiz. \t tab. verticale \v retour à la ligne \n nouvelle page \f retour chariot \r caractère nul \0 Informatique Générale Langage C 6 Isabelle Ferrané

7 REMARQUE : une notation équivalente utilise la valeur octale du code ASCII associé au caractère : \t équivaut à \11. Dans ce cas la notation octale n'est pas précédée du marqueur 0. ATTENTION! : le caractère nul '\0' est le caractère de code ASCII zéro. Ne pas confondre avec la lettre O ni avec le chiffre zéro (code ASCII 48). Notation symbolique pour les caractères spéciaux : guillemet \" point d'interrogation \? quote \' back slash \\ Précédés du caractère \, les caractères spéciaux sont interprétés comme de simples caractères. I-4.4. Les chaînes de caractères Une chaîne de caractères est représentée par une suite de caractères délimitée par des guillemets. Elle peut comporter des caractères non visualisables et des caractères spéciaux : "" /* représente la chaîne vide */ "chaîne de caractères" "\"chaîne entre guillemets\"" "retour_a_la_ligne\n" ATTENTION! : le compilateur place automatiquement le caractère '\0' à la fin de chaque chaîne de caractères. ex : "chaine" comporte 6 caractères visualisables et est stockée sur 7 caractères : 'c' 'h' 'a' 'i' 'n' 'e' '\0' I-5. Les variables et les tableaux Variable : identificateur qui désigne une information d'un type donné. La valeur d'une variable peut être modifiée au cours du programme. Par contre, le type de la variable spécifié lors de sa déclaration est fixé une fois pour toute. variable simple désigne des données élémentaires : entier, caractère, réel, Informatique Générale Langage C 7 Isabelle Ferrané

8 variable composée regroupe un ensemble de données : tableau, structure, union, énumération. Tableau : variable composée représentant un ensemble de valeurs de même type. Chaque valeur ou élément du tableau est identifiée au moyen d'un indice. Si TAB est le nom du tableau alors TAB[i] désigne l'élément d'indice i ATTENTION! : si N est la taille du tableau alors l'indice prend obligatoirement ses valeurs dans l'intervalle 0..N-1. Si TAB est le nom du tableau, alors TAB[0] désigne le premier élément du tableau et TAB[N-1] le dernier. Tableau multidimentionnel : un tableau peut avoir plusieurs dimensions. Il est alors défini comme un tableau d'éléments qui sont eux-mêmes des tableaux. Si TAB est un tableau à 2 dimensions DIM1 et DIM2, alors, pour toute valeur de i comprise entre 0 et DIM1-1, TAB[i] est un tableau unidimentionnel comportant DIM2 éléments, désignés par TAB[i][j] avec j compris entre 0 et DIM2-1. I-5.1. Déclaration de variable simple ou de tableau Toute variable simple ou composée utilisée dans un programme C doit avoir préalablement été déclarée. Une déclaration associe une variable ou un groupe de variables à un type de données. Déclaration d'une variable simple : TYPE nom_variable ; Déclaration d'un tableau à une (1) ou N dimensions (2) : (1) TYPE nom_tableau [taille]; (2) TYPE nom_tableau [t1][t2]...[tn]; Informatique Générale Langage C 8 Isabelle Ferrané

9 IMPORTANT : la taille d'un tableau spécifie le nombre maximum d'éléments par dimension considérée. Elle doit être une constante entière strictement positive. Ne pas utiliser une variable pour la définir. Exemple de déclaration : int tab[5], indice, i, j, k; char car, chaine[20]; float x, y, nb_reels[10][5]; tab est un tableau de 5 entiers, chaine un tableau de 20 caractères et nb_reels un tableau à 2 dimensions (10 lignes x 5 colonnes), chaque élément étant un nombre flottant. I-5.2. Initialisation de variable simple ou de tableau Opération qui consiste à attribuer une valeur initiale à une variable lors de sa déclaration. Initialisation d'une variable simple : TYPE nom_variable = val_initiale ; Exemple d'initialisation : Initialisation d'un tableau : int indice = 0 ; char car = '$' ; float x = 0.0, y = 0.0 ; long int res = 0L ; TYPE nom_tab [ ] = { ens_val_initiales } ; REMARQUE : Dans ce cas seulement, on peut ne pas spécifier la taille du tableau, celle-ci est alors déduite de la taille de la valeur initiale attribuée. Exemple d'initialisation : int filtre_binaire [] = {0, 1, 0, 0, 1} ; char chaine[] = "initialisation" ; char voyelle[6] = {'a','e','i','o','u','y'} ; float matrice[2][2] = { {0.0, 1.0} {1.0,0.0} }; filtre_binaire est un tableau de 5 entiers et chaine un tableau de 15 caractères (14 visualisables + 1 marquant la fin de chaîne). Informatique Générale Langage C 9 Isabelle Ferrané

10 I-6. Les expressions Expression : représente une donnée élémentaire (nombre ou caractère). expression simple désigne une seule entité : constante, variable, élément de tableau ou appel à une fonction : 5, X, T[i], f(x),... expression complexe combinaison d'entités appelées opérandes et reliées par des opérateurs : X + 5, Y > (Z+2),... Conversion implicite : effectuée automatiquement si les opérandes ne sont pas de même type mais de type compatible. Ex : float X = 0 ; /* 0 --> 0.0 */ Conversion explicite : (ou cast) expression typée qui indique que la valeur de l'expression doit être convertie dans le type spécifié avant d'être utilisée. (TYPE) expression ATTENTION! : lors d'une conversion implicite ou explicite, le type de l'expression n'est pas modifié, seule sa valeur est convertie. Exemple : float MOY = 0.0; int A = 15, B = 26; MOY = (float) (A + B) / 2; Le résultat de l'expression A + B est converti explicitement en valeur flottante (41 --> 41.0). La valeur 2 fait alors l'objet d'une conversion implicite (2 --> 2.0). Ainsi MOY récupère 20.5 au lieu de I-6.1. Expressions et opérateurs arithmétiques Opérateurs binaires (2 opérandes) : + addition - soustraction * multiplication / division entière ou réelle % modulo ou reste de la division entière Informatique Générale Langage C 10 Isabelle Ferrané

11 ATTENTION! : contraintes de type : les opérandes doivent représenter des valeurs numériques. - L'opérateur % n'admet que des opérandes de type entier. - Si les 2 opérandes de l'opérateur / sont des entiers alors le résultat obtenu est le quotient de la division entière. REMARQUE : si c1 et c2 sont des variables de type caractère (char) alors c1+c2 (resp. c1-c2) revient à faire la somme (resp. la différence) des codes ASCII. Exemple : 'B'-'A' --> 1 Opérateurs unaires (1 opérande) : - valeur opposée ex : Y = -X ; ++ incrémentation ex : I++ ou ++I -- décrémentation ex : I-- ou --I ATTENTION! : La position des 2 opérateurs ++ et -- joue un rôle dans l'évaluation du résultat. I-6.2. Expressions et opérateurs relationnels Ces opérateurs sont utilisés pour construire des expressions logiques traduisant des conditions vraies ou fausses : FAUX valeur égale à 0 ; VRAI 1. opérateurs relationnels : < inférieur > supérieur <= inférieur ou égal >= supérieur ou égal opérateurs de comparaison : == égalité!= différent I-6.3. Expressions et opérateurs logiques Ces opérateurs permettent la combinaison (et, ou) ou la négation (non) d'expressions logiques (cf. I-6.2). Toute condition dont la valeur est différente de zéro est considérée comme vraie. Opérateurs binaires : && et logique ou logique Opérateur unaire :! non logique Informatique Générale Langage C 11 Isabelle Ferrané

12 I-6.4. Opérateurs d'affectation Affectation simple : nom_var = expression ; ATTENTION! : Ne pas confondre cet opérateur avec l'opérateur testant l'égalité de 2 expressions (==). REMARQUE : Une expression d'affectation renvoie la valeur affectée après conversion si nécessaire. On peut donc la trouver dans une expression plus complexe. while ( c = getchar() )!= '$' )... c reçoit la valeur du caractère saisi au clavier. Cette valeur est ensuite comparée au caractère $. Affectation combinée : nom_var = nom_var + expression ; peut se réécrire nom_var += expression ; Même chose avec les autres opérateurs arithmétiques binaires : - * / % utilisés dans des affectations peuvent se réécrire respectivement -=, *=, /=, %=. I-6.5. Priorité des opérateurs Priorité maximale ! (TYPE) opérateurs unaires * / % - + < <= > >= ==!= && = += -= *= /= %= affectations Priorité minimale Informatique Générale Langage C 12 Isabelle Ferrané

13 I-6.6. Opérateurs pour la manipulation de données binaires Opérateur unaire (opérande entier) : ~ complément à un Opérateurs binaires (opérandes de type entier) : & et binaire ou binaire ^ ou exclusif binaire >> décalage à droite << décalage à gauche Dans les opérations de décalage, le second opérande doit être un entier non signé. Ces opérateurs peuvent également être combinés avec l'opérateur d'affectation ( &=, =, ^=, >>=, <<= ). I-7. Les instructions. Instruction : il existe 3 catégories d'instructions pour traduire une action plus ou moins complexe : les instructions simples, les instructions composées et les instructions de contrôle. I-7.1. Instructions simples Toute instruction simple se termine par un ;. Il s'agit généralement d'une expression d'affectation ou d'un appel à un sous-programme. Exemple d'instructions simples : a = 3 ; c = a + b ; i++ ; j += i ; printf("resultat = %d\n", c) ; ; /* instruction vide ou nulle */ I-7.2. Instructions composées ou bloc d'instructions Ensemble d'instructions (simples et/ou composées et/ou de contrôle) encadré par des accolades ( {...} ) et appelé généralement bloc d'instructions. Informatique Générale Langage C 13 Isabelle Ferrané

14 Exemple de bloc d'instructions : { /* debut de bloc */ printf("message d'erreur") ; traiter_erreur (); } /* fin de bloc : pas de ; */ I-7.3. Instructions de contrôle Elles traduisent les structures de contrôle et permettent de réaliser certaines fonctionnalités comme les tests logiques, les boucles et les sélections. I L'instruction if else Utilisée pour les tests et les expressions conditionnelles.. Test simple : Exemples de tests :. Test avec alternative : if (expression) instruction expression expression logique simple (variable, appel de fonction,...) ou complexe (conjonction et/ou disjonction et/ou négation de condition) instruction instruction (simple, composée ou de contrôle) qui n'est exécutée que si expression est vraie (=> valeur différente de 0), sinon elle est ignorée. ATTENTION! : En langage C il n'y a pas de mot-clé then if ( Y!= 0 ) X = X/Y ; if (trouve_solution) printf("ok!"); if ( (X>0) && (Y>0) ) { printf("ok!"); Z = X % Y; } if (expression) instruction_1 else instruction_2 Informatique Générale Langage C 14 Isabelle Ferrané

15 La clause ELSE exprime une alternative. instruction_1 et instruction_2 sont des instructions qui seront exécutées en fonction de la valeur de vérité de expression. Si expression est vraie (valeur différente de 0) alors instruction_1 est exécutée et instruction_2 ignorée. Sinon (expression vaut 0) instruction_2 est exécutée et instruction_1 ignorée. Exemple de tests avec alternative : if ( Y!= 0 ) X = X/Y ; else printf("division par zero \n"); ATTENTION! : On peut imbriquer plusieurs instructions de ce type, mais il faut faire attention aux ambiguïtés, c'est-à-dire savoir à quel if se rapporte un else. Opérateur conditionnel? : : Certaines alternatives simples peuvent s'écrire au moyen d'un opérateur plutôt qu'avec l'instruction if else. (expression_1)? expression_2 : expression_3 ; équivaut à if (expression_1) expression_2 ; else expression_3 ; Exemple d'utilisation de l'opérateur conditionnel : if ( A < B ) MIN = A ; else MIN = B ; se traduira par MIN = ( A < B )? A : B ; I L'instruction while Permet la construction de boucles (exécution itérative d'une instruction tant qu'une condition est vérifiée) while (expression) instruction La partie instruction est exécutée tant que expression est vraie (valeur différente de 0). Informatique Générale Langage C 15 Isabelle Ferrané

16 IMPORTANT : Pour "entrer" dans la boucle il faut s'assurer que la condition exprimée par expression est vraie. On "sort" de la boucle lorsque la condition correspondant à expression est fausse. La partie instruction doit donc obligatoirement modifier à un moment donné la valeur de l'expression sinon la boucle sera infinie! ATTENTION! : Il n'y a pas de mot-clé do associé à une boucle while Exemple de boucle WHILE: /* programme d'affichage de 10 chiffres */ #include <stdio.h> void main(void) { int chiffre = 0; while( chiffre <= 9) { printf("%d\n", chiffre); chiffre++; } } I L'instruction do while Autre type de boucle ayant pour rôle de répéter l'instruction tant que la condition posée par l'expression est vraie. La seule différence qui existe entre une boucle WHILE et une boucle DO WHILE est que, dans le premier cas, le test est fait avant de rentrer dans la boucle et dans le second il est fait après le premier passage. Par conséquent, la partie instruction d'une boucle DO WHILE est exécutée au moins une fois. do instruction while (expression) ; Exemple de boucle DO WHILE: /* programme d'affichage de 10 chiffres */ #include <stdio.h> void main(void) { int chiffre = 0; do printf("%d\n", chiffre++); while ( chiffre <= 9) ; } I L'instruction for Informatique Générale Langage C 16 Isabelle Ferrané

17 Troisième type de boucle existant. Il permet d'exécuter de manière itérative une instruction un nombre donné de fois. for (expression_1 ; expression_2 ; expression_3) instruction expression_1 initialise la variable de boucle (affectation) ; expression_2 représente la condition à satisfaire pour exécuter la partie instruction. (attention! : ce n'est pas l'expression de la condition d'arrêt). expression_3 sert à modifier la variable de boucle (incrémentation, décrémentation ou affectation). instruction séquence de code à exécuter plusieurs fois. ATTENTION! : Pas de mot-clé do dans un for. Une boucle for est totalement équivalente à une séquence de code incluant une boucle while (cf exemple I.7.3.2). Exemple de boucle FOR : /* programme d'affichage de 10 chiffres */ #include <stdio.h> void main(void) { int chiffre; } for (chiffre = 0 ; chiffre <= 9 ; chiffre++) printf("%d\n", chiffre); I L'instruction switch Ce type d'instruction permet le branchement sur un groupe d instructions à partir d un point d entrée qui est fonction de la valeur de l expression. Informatique Générale Langage C 17 Isabelle Ferrané

18 switch (expression) { case valeur1 : suite_instructions_1 case valeur2 : suite_instructions_2... case valeurn-1 : suite_instructions_n-1 case valeurn : suite_instructions_n } ATTENTION! : Si la valeur de l expression est égale à valeur1, toutes les séquences d instructions (1 à N) sont exécutées successivement. Si la valeur de l expression correspond à l avant dernier case, seules les 2 dernières suites d instructions sont exécutées successivement, etc. L'instruction break provoque la sortie du bloc d instructions dans lequel elle se trouve. L utilisation systématique de l instruction break dans une instruction switch, permet de n exécuter que la suite d instructions correspondant réellement au case. switch (expression) { case valeur1 : suite_instructions_1 break; case valeur2 :... default : suite_instructions_n } suite_instructions_2 break; expression est évaluée et doit renvoyer un entier ou un caractère. La valeur obtenue détermine alors directement la suite_instructions à exécuter. Si aucune valeur ne correspond, aucune séquence d'instructions n'est exécutée à moins qu'une clause default ait été définie. Dans ce cas, ce sont les instructions associées qui sont exécutées. On peut exprimer le fait qu'une séquence d'instructions soit commune à plusieurs valeurs comme le montre l'exemple suivant. Informatique Générale Langage C 18 Isabelle Ferrané

19 REMARQUE : Ce type d'instruction est plus clair qu'une suite de if else imbriqués. Exemple de SWITCH :... printf("voulez-vous continuer?: "); switch( choix = getchar() ) { case 'o' : case 'O' : fin = 0; break; case 'n' : case 'N' : fin = 1; break; default : printf("repondre par o / n "); }... II-. Structure d'un programme en langage C Un programme en langage C se décompose généralement en plusieurs parties. II-1. Les directives Ces directives débutent par le caractère # et s'adressent au préprocesseur. Celui-ci opère juste avant la phase de compilation proprement dite. Son rôle est de remplacer chaque directive par ce qu'elle représente. II-1.1. Inclusion de fichiers #include Le contenu du fichier mentionné sera inclus dans le fichier source. Il s'agit en général d'un fichier contenant des déclarations de fonctions et de variables externes. Si le fichier inclus correspond à une bibliothèque de fonctions standards, son nom doit être spécifié entre < et > : #include <stdio.h> S'il s'agit d'un autre type de fichier, son nom sera donné entre guillemets : #include "mon_fichier.h" Informatique Générale Langage C 19 Isabelle Ferrané

20 II-1.2. Définition de constantes symboliques #define permet la définition d'une constante symbolique. Avant la compilation, chaque occurrence de celle-ci est remplacée par la valeur qui lui a été associée. #define NOM_CONST valeur Dans d'autres cas cette directive permet simplement de définir une constante comme existante. Son existence pourra être testée avec les directives conditionnelles #ifdef ou #ifndef II-1.3. Compilation conditionnelle #if, #ifdef, #ifndef, #elif, #else, #endif,... Groupe de directives qui permettent de faire de la compilation conditionnelle. Dans l'exemple suivant, la valeur attribuée à la constante symbolique CST est différente suivant la version du programme utilisée : #if VERSION == 1 #define CST 10 #elif VERSION == 2 #define CST 20 #else #define CST 15 #endif Elles permettent également d'éviter les inclusions multiples d'un même fichier lorsque l'on fait de la programmation modulaire. Tout fichier pouvant être inclus plusieurs fois devra alors débuter par : #ifndef FIC_INCLUS #define FIC_INCLUS /* partie à inclure */ #endif II-2. Les déclarations En langage C, tout objet, que ce soit une constante, une variable ou une fonction, doit être défini avant d'être utilisé. Cependant, certains problèmes de visibilité peuvent se poser lorsque : Informatique Générale Langage C 20 Isabelle Ferrané

21 - la définition se trouve dans le même fichier mais après la partie de code utilisant l'objet en question (référence "en avant"); - la définition se trouve dans un autre fichier source ou unité de compilation, faisant partie du même programme (compilation séparée). Dans ces 2 cas, il est indispensable d'inclure, avant toute utilisation, une déclaration indiquant au compilateur que l'objet utilisé est défini ailleurs : soit ultérieurement dans le même fichier, soit dans un autre fichier. II-3. Les définitions de données Définir un objet consiste à donner toutes ses caractéristiques : le type, le nom, la taille lorsqu'il s'agit d'un tableau, et éventuellement la valeur initiale. Exemple : /* définition d'une constante */ const float C1 = 15.5 ; /* définition de variables */ int TOTAL = 0, RES1, RES2 ; /* définition de tableaux */ char ch_res[10], message [] = "*** ERREUR ***"; A la différence d'une déclaration, qui n'est qu'un rappel de l'existence d'un objet, une définition associe un identificateur à un objet et s'accompagne généralement d'une allocation de l'espace mémoire nécessaire pour stocker la valeur de la donnée. Le programmeur a également la possibilité de définir un type avec le mot-clé typedef. Dans ce cas il s'agit plutôt d'un "renommage" et ne provoque pas d'allocation mémoire. II-4. Les définitions de fonctions Le rôle d'une fonction est d'effectuer une tâche précise, à la demande d'une autre partie du programme. La fonction appelée et la partie appelante peuvent avoir à communiquer (échange d'informations). Chaque définition de fonction comporte donc 2 parties : Informatique Générale Langage C 21 Isabelle Ferrané

22 la spécification : cette partie rassemble les informations concernant l'interface de la fonction avec la partie appelante : nom de la fonction, type de la valeur renvoyée et liste des paramètres formels. le corps : il s'agit d'un bloc d'instructions comportant généralement une instruction return et correspondant au travail effectué par la fonction Syntaxe incluant la notion de prototypage de fonction (C norme Ansi) Si la fonction admet un ou plusieurs paramètres, la liste typée comportant le type et le nom de chaque paramètre formel doit être spécifiée entre parenthèses dans l entête de la fonction (1). Si aucun paramètre n est nécessaire le mot clé void est spécifié entre parenthèses (2). (1) type_retour nom_fonction ( type1 nom1,... typen nomn) { /* définition de variables locales */... /* instructions */... } (2) type_retour nom_fonction ( void ) { /* définition de variables locales */... /* instructions */... } L'intérêt du prototypage est de permettre au compilateur de contrôler la bonne utilisation d'une fonction. Ce contrôle porte sur le type de la valeur de retour ainsi que sur la cohérence des paramètres effectifs par rapport aux paramètres formels spécifiés dans la définition de la fonction (nombre et type). Sans ce contrôle les erreurs se produiront lors de l'exécution du programme. IMPORTANT : lorsqu'une fonction n'est pas destinée à renvoyer une valeur, type_retour doit être défini comme void. Informatique Générale Langage C 22 Isabelle Ferrané

23 Exemple : void f1 (void) f1 est définie comme ne renvoyant rien et n'admettant pas de paramètres. II-5. La fonction principale : main Indispensable dans un programme C, ce nom prédéfini indique qu'il s'agit du point d'entrée du programme. L'exécution du programme commencera toujours par l'exécution du code de la fonction main. Le corps de cette fonction ne comporte pas d'instruction return. void main(void) { /* définition de variables locales */... /* instructions */... } REMARQUE : cette fonction peut éventuellement être paramétrée (selon une syntaxe spécifique), les valeurs des paramètres seront alors fournies lors de l'appel du programme. L interface ou entête est alors : void main(int argc, char **argv) argc représente le nombre de paramètres et argv est un pointeur de pointeur de caractères et pointe sur le premier pointeur qui donne accès à la chaîne de caractères correspondant au premier argument fourni lors de l appel du programme. La structure argv est créée et gérée par UNIX (lien avec la variable shell argv) le programme ne fait que l utiliser. La fonction main peut également renvoyer un code de retour. A ce moment-là, le type de la valeur de retour n est plus void mais int. int main(void) III. Les bibliothèques de fonctions standards Informatique Générale Langage C 23 Isabelle Ferrané

24 Différentes bibliothèques de fonctions standards sont à la disposition des développeurs de programmes en langage C. Chacune d elles est dédiée à un type d utilisation particulier et est constituée d un fichier.h. Exemple : stdio.h : math.h : string.h : fonctions de gestion des entrées-sorties fonctions mathématiques fonction de gestion des chaînes de caractères Ces fichiers contiennent généralement : - les directives définissant les constantes symboliques utilisées (ex : NULL, RAND_MAX, ); - les définitions de structures et de types utilisés par les fonctions de la bibliothèque (FILE, ); - le prototypage des fonctions. III-1. Utilisation des fonctions standards Pour pouvoir utiliser une fonction standard, il faut inclure le fichier correspondant à la bibliothèque contenant la déclaration de la fonction Pour cela il faut utiliser la directive #include (cf. II-1). La première bibliothèque dont on a besoin dans un programme est celle permettant l'échange d'informations entre la machine et les dispositifs d'entrées-sorties (clavier, écran, fichiers textes, fichiers binaires, ) : la bibliothèque stdio.h III-2. La bibliothèque de fonctions standard stdio.h Certaines des fonctions de cette bibliothèque lisent sur l'entrée standard ou écrivent sur la sortie standard. D'autres permettent le transfert d'informations depuis ou vers des fichiers de données. Ce paragraphe concerne les fonctions directementliées aux entrée-sorties standards. III-2.1 Les entrées-sorties de caractères la fonction getchar int getchar() Lit un caractère sur l'entrée standard (clavier par défaut) et renvoie le code ASCII du caractère lu (int) Informatique Générale Langage C 24 Isabelle Ferrané

25 la fonction putchar int putchar( char c) Ecrit sur la sortie standard (écran par défaut) le caractère c donné en paramètre et renvoie le code ASCII du caractère écrit (int) III-2.2 Les entrées-sorties de chaînes de caractères la fonction gets char * gets( char * ch) Lit une suite de caractères saisie au clavier et terminée par un retour à la ligne puis la place dans le tableau de caractères désigné par le paramètre fourni (ch). Le caractère de fin de ligne '\n' est normalement remplacé par le marqueur de fin de chaîne de caractères '\0' la fonction puts int puts( const char * ch) Ecrit sur la sortie standard la chaîne de caractères donnée en paramètre, suivie d'un retour à la ligne. Si l'opération d'écriture s'est déroulée sans problème, la valeur renvoyée est celle du nombre de caractères écrits, sinon c'est la valeur correspondant à EOF (-1) qui est renvoyée. III-2.3 Les entrées-sorties formatées Ces fonctions permettent de lire et d'écrire des données de natures différentes : valeurs numérique, caractères, chaînes de caractères. Il est donc indispensable de spécifier le format de chaque donnée à traiter. la fonction scanf int scanf( const char * format, [arg1,, argn)) Lit des données sur l'entrée standard. Ces données seront interprétées suivant les spécification fournies dans la chaîne format donnée en paramètr, et éventuellement stockées dans les variables représentées par arg1, argn. Informatique Générale Langage C 25 Isabelle Ferrané

26 - la chaîne format : il s'agit d'une chaîne de caractères directement donnée entre " " et qui précise comment le flot de données présent sur l'entrée standard doit être interprété. Elle est composée de groupes de caractères appelés spécificateurs de format. - le spécificateur de format : il définit le type et éventuellement la taille de la donnée à lire. Il débute par le caractère %, suivi éventuellement d'une valeur entière correspondant à la taille maximum de la donnée (= nombre de caractères s'il s'agit d'une chaîne ou nombre de chiffres s'il s'agit d'une donnée numérique) et se termine par un caractère indiquant en quel type la donnée doit être convertie (ex : %c, %5d, ). Caractère de Signification Type correspondant conversion c simple caractère char s chaîne de caractères char * terminée par '\0' d entier décimal int o entier sous forme unsigned int octale x entier sous forme unsigned int hexadécimale i entier sans distinction int de forme h entier court short u entier décimal non unsigned int signé l entier long long e, f ou g Nombre à virgule float flottante lf Nbre à virg. flottante double double précision Ainsi la donnée 1 peut être, selon le caractère utilisé, considérée comme un caractère ('1'), une chaîne de caractères ("1"), un entier (1) ou un réel (1.0).. - les arguments : ils désignent l'endroit où la donnée lue va être stockée. Dans le cas d'une donnée simple (entier, réel ou caractère), il ne s'agit pas directement du nom de la variable qui va recevoir la valeur mais de son adresse (utilisation de l'opérateur d'adressage &. Ex : N &N) Informatique Générale Langage C 26 Isabelle Ferrané

27 Attention! : le cas des tableaux de caractères est différent IMPORTANT : Le type de la donnée où doit être stockée la valeur lue doit être compatible avec celui du format associé. Il doit y avoir autant d'arguments que de spécificateurs de types. Exemple : int X, Y; float Z; char C, ch[20]; scanf("%d %f", &X, &Z); scanf("%c%d%s", &C, &Y, CH); scanf("%c%c%c", &CH[0], &CH[1], &CH[2]); ATTENTION!: La chaîne format peut contenir éventuellement d'autres caractères que ceux composant les spécificateurs de format. Cela signifie alors que ceux-ci devront être trouvés tels quels dans le flot de données. S'il n'y a pas correspondance alors la lecture sera interrompue. La fonction scanf renvoie le nombre de données lues. S'il y un problème de correspondance entre un format et une donnée, le nombre renvoyé est 0. Si le flot de données prend fin alors que d'autres données restent à lire la valeur renvoyée est -1 (EOF). la fonction printf int printf( const char * format, [arg1,, argn]) Ecrit des données sur la sortie standard. Si des arguments, arg1,, argn sont spécifiés ([ ] signifiant ici facultatif), leur valeur respective est écrite sur la sortie standard conformément à la spécification de format fournie dans la chaîne format donnée en paramètre. - la chaîne format : il s'agit d'une chaîne de caractères directement donnée entre " " et précisant comment le flot de données doit être interprété pour être écrit sur la sortie standard. Elle est composée de texte et/ou de spécificateurs de format. - le spécificateur de format : il définit le type et éventuellement la taille de la donnée à écrire. Il débute par le caractère %, suivi : - d'une valeur entière, qui, lorsqu'elle est précisée correspond à la taille minimum de la donnée (= nombre de caractères s'il s'agit d'une chaîne ou nombre de chiffres s'il s'agit d'une donnée numérique). Informatique Générale Langage C 27 Isabelle Ferrané

28 - d'une seconde valeur entière, qui, lorsqu'elle est précisée indique soit le nombre de chiffres à écrire après le point décimal lorsque la donnée est de type float ou double, soit le nombre maximum de caractères de la chaîne à écrire réellement. Afin de la distinguer de la taille minimum, cette valeur, appelée précision, est toujours précédée d'un point. - du caractère de conversion précisant la forme selon laquelle la donnée devra être écrite. (ex : %s, %15s, %.3f, %5.3f, ) Caractère de Signification Type correspondant conversion c simple caractère char s chaîne de caractères char * terminée par '\0' d ou i entier décimal signé int o entier sous forme unsigned int octale (non précédé de 0) x entier sous forme unsigned int hexadécimale (non précédé de 0x) f Valeur réelle ( avec point décimal mais sans exposant) float ou double e Valeur réelle ( avec un seul chiffre avant le point décimal et une partie exposant) g e ou f avec indication d'une précision l Combiné avec d, u,o,i ou x pour un entier long float ou double Long int - les arguments : désignent les valeurs à écrire. Ils peuvent correspondre à une constante, une expression, un appel de fonction, une variable, un tableau de caractères, Contrairement à la fonction scanf, il ne faut pas préciser l'adresse des variables simples. IMPORTANT : Le type de la donnée à écrire doit être compatible avec le format spécifié. Le nombre de spécificateurs de type donnés dans la chaîne format doit correspondre au nombre de données à écrire. Informatique Générale Langage C 28 Isabelle Ferrané

29 Exemple : int X = 10, Y = 3; char ch[] = "EXEMPLE"; /* évaluation de la moyenne et affichage */ /* du résultat 3 chiffres après la virgule */ printf("moyenne de %d et %d = %.3f", X, Y, (float) X + Y /2); /* affichage de la chaîne EXEMPLE complétée */ /* 3 espaces pour arriver à 10 caractères */ /* minimum */ printf("%10s", ch); /* affichage d'un simple texte avec */ /* tabulation \t et retour à la ligne \n */ printf("\tceci est uniquement du texte\n"); Des indicateurs de format peuvent modifier l'opération de lecture ou d'écriture. Ceux-ci sont alors placés après le caractère % débutant le spécificateur de type. Indicateur Exemple Action correspondante - %-d l'écriture de la donnée est justifiée à gauche. * %*s la donnée est lue mais pas mémorisée % %% écriture du caractère % # %#o les valeurs octales ou hexadécimale sont précédées de leur marqueur respectif 0 et 0x La fonction printf renvoie le nombre de données émises sur la sortie standard. En cas de problème elle renvoie -1 (EOF). III-2.4 Les Entrées-Sorties dans un fichier Les entrées-sorties se font soit sur les fichiers standards (stdin, stdout, stderr), soit sur des fichiers de données enregistrés sur le disque. Il s'agit alors Informatique Générale Langage C 29 Isabelle Ferrané

30 de fichiers textes (suite de caractères ASCII) ou de fichiers binaires (suite de blocs d'octets correspondant par exemple à des enregistrements). Toutes les fonctions d'entrées-sorties se trouvent dans la bibliothèque standard stdio.h. Ne sont données ici que les déclarations associées aux principales fonctions. III Notion de descripteur de fichier : type FILE Pour manipuler un fichier de données dans un programme C, il faut utiliser un pointeur sur un type prédéfini dans stdio.h : le type FILE. /* pointeur nécessaire a l'utilisation */ /* d'un fichier de données */ FILE * ptr_fic; Un élément de type FILE, appelé descripteur de fichier, est une structure contenant les informations relatives au fichier auquel il est associé (mode d'ouverture du fichier, type du fichier, position courante,...). Le programmeur n'a pas accès directement au contenu de cette structure. Il ne peut manipuler le fichier que via le pointeur associé dans la mesure où celui-ci a reçu l'adresse du descripteur. Ce pointeur est appelé nom interne du fichier. III Ouverture d'un fichier : la fonction fopen Avant de pouvoir être utilisé, tout fichier de données doit être ouvert. Pour cela, il faut préciser le nom externe du fichier (chaîne de caractères représentant le nom du fichier) et le mode d'ouverture souhaité. Connaissant ces paramètres, la fonction fopen renvoie soit l'adresse du descripteur associé au fichier ouvert, soit NULL si l'ouverture n'a pu être effectuée. FILE * fopen ( char* NOM, char* MODE) ; Attention!! : Toujours tester la valeur du pointeur après ouverture du fichier car s'il y a eu un problème sa valeur est égale à NULL, ce qui peut avoir des conséquences fâcheuses, si le pointeur est utilisé pour la suite du traitement. Spécification du mode d'ouverture : "r" ouverture en lecture uniquement et "r+" en lecture/écriture Informatique Générale Langage C 30 Isabelle Ferrané

31 Si le fichier n'existe pas alors il y a erreur d'ouverture. "w" ouverture en écriture uniquement et "w+" en lecture/écriture. Si le fichier n'existe pas alors il est créé ; sinon son contenu est effacé. "a" ouverture en écriture uniquement et "a+" en lecture/écriture. Si le fichier n'existe pas alors il est créé ; sinon l'écriture se fait en fin de fichier (l'ancien contenu est conservé). Attention!! : Pour les opérations de lecture/écriture sur un même fichier il faut gérer la position courante pour ne pas écrire sur les données à lire. III Fermeture d'un fichier : la fonction fclose Lorsque le fichier représenté par son nom interne, n'est plus utilisé par le programme, il doit être fermé. int fclose ( FILE* PTR_FIC) ; III Entrées-Sorties sur un fichier texte On retrouve des fonctions similaires à celles utilisées pour les entrées-sorties standard (cf. III-2.1, III-2.2 et III-2.3). Elles admettent un paramètre supplémentaire précisant le nom interne du fichier (pointeur sur structure de type FILE) sur lequel l'opération de lecture ou d'écriture doit s'effectuer. On dispose de fonctions traitant : - un seul caractère : getc, fgetc, et putc, fputc, - une chaîne de caractères : fgets et fputs, - des entrées-sorties formatées : fscanf et fprintf. int fgetc(file*) ou int getc(file*) Lit un caractère simple dans le fichier désigné par le paramètre fourni int fputc(char,file *) ou int putc(char,file *) Ecrit le caractère donné par le premier dans le fichier désigné par le second paramètre. char* fgets(char*,int,file *) Informatique Générale Langage C 31 Isabelle Ferrané

32 Lit une chaîne d'une longueur donnée dans le fichier designé par le second paramètre et la stocke à l'adresse fournie par le premier paramètre. int fputs(char*,file *) Ecrit la chaîne donnée par le premier paramètre dans le fichier désigné par le second paramètre int fscanf(file*,char*...) Lit des données dans le fichier désigné par le premier paremètre, selon le format donné par la chaîne format sur le même principe que la fonction scanf. int fprintf(file*,char*...) Ecrit des données dans le fichier désigné par le premier paramètre, selon le format spécifié par la chaîne format sur le même principe que la fonction printf III Entrées-Sorties sur un fichier binaire Les fonctions d'entrées-sorties ne sont pas les mêmes que pour un fichier texte. Il s'agit de transférer des blocs d'octets de même taille depuis (lecture), ou vers (écriture) le fichier ouvert. Pour cela on a besoin, en plus du nom interne du fichier (pointeur sur FILE), de l'adresse du premier bloc, de la taille d'un bloc et le nombre de blocs transférés simultanément. La lecture et l'écriture d'un ou plusieurs blocs se font respectivement grâce aux fonctions fread et fwrite à partir de la position courante. Celle-ci est ensuite déplacée du nombre d'octets correspondant aux données traitées. size_t fread(char*, int, int,file *) Transfère des données d'un fichier de données binaire (= suite d'octets) dans la zone désignée par le premier paramètre. Les blocs d'octets à transférer ont une taille donnée par le deuxième paramètre, le troisième précisant le nombre de blocs à transférer, et le dernier désignant le fichier source. size_t fwrite(char*,int,int,file *) Transfère, vers le fichier de données désigné par le troisième paramètre, des blocs d'octets dont la taille est donnée par le deuxième paramètre et Informatique Générale Langage C 32 Isabelle Ferrané

33 le nombre par le troisième. L'adresse de la zone où se trouve les données à transférer correspond à l'adresse fournie comme premier paramètre. La position courante correspond à l'adresse du prochain octet qui fera l'objet d'une opération de lecture ou d'écriture. La valeur de la position courante peut être obtenue via la fonction ftell et modifiée via les fonctions fseek et rewind. long int ftell(file*) Renvoie la position courante du fichier désigné par le paramètre int fseek(file*,long int, int) Décale la position courante du fichier désigné par le premier paramètre du nombre d'octets spécifié par le deuxième paramètre à partir de l'adresse donnée en troisième paramètre. void rewind(file*) Repositionne la position courante au début du fichier donné en paramètre. Remarque : size_t est un type prédéfini dans la bibliothèque stdlib.h bibliothèque et correspond à tout type d'entier, ce qui permet l écriture de fonctions plus génériques. III Autres fonctions de manipulation de fichier : La bibliothèque stdio.h dispose également de fonctions permettant de contrôler les flux de données. La fonction feof indique si la fin de fichier a été atteinte ou non en renvoyant respectivement une valeur non nulle, 0 sinon. int feof(file*) A toute opération de lecture ou d'écriture sur un fichier donné est associé un buffer fonctionnant normalement en mode bloc ; c'est-à-dire que celui-ci mémorise la donnée à transférer et le transfert n'est effectué que lorsque le buffer est plein. La fonction fflush permet de courcircuiter ce mécanisme en provoquant le transfert immédiat des données. int fflush(file*) Informatique Générale Langage C 33 Isabelle Ferrané

34 D'autres fonctions permettent d'agir sur le buffer en changeant ses caractéristiques : setbuf, setvbuf. void setbuf(file*, char *) void setvbuf(file*, char *, int, size_t) ***************************************************************** Pour connaître les spécifications détaillées des fonctions de la bibliothèque stdio.h, vous pouvez consulter le manuel en ligne : man nom_fonction ***************************************************************** EXEMPLE d'utilisation des fonctions intervenant dans la manipulation de fichiers de données texte : #include <stdio.h> void main (void) { FILE * ptr_fic; char mot[11]; int nb; /*ouverture en lecture du fichier de nom mon_fic */ ptr_fic = fopen("mon_fic", "r"); /* pour la suite ptr_fic désigne le fichier */ if(ptr_fic!= NULL) { /* ouverture OK => lecture de la 1ere ligne */ fscanf(ptr_fic, "%10s %d", MOT, &NB); while(!feof(prt_fic)) { /* traitement à faire sur tout le fichier */... /* lecture ligne suivante */ fscanf(ptr_fic, "%10s %d", MOT, &NB); } fclose(ptr_fic); /* fermeture du fichier */ } else { /* message sur la sortie standard erreur */ fprintf(stderr, "Probleme d'ouverture"); /* sortie du programme */ exit(1); } /* autres instructions */... } III-3 Autres bibliothèques et fonctions standards. III.3.1. Fichier math.h : Fonctions mathématiques. Informatique Générale Langage C 34 Isabelle Ferrané

35 Pour utiliser les fonctions mathématiques, il faut non seulement inclure ce fichier en début de programme mais également compiler avec l'option -lm. int abs(int) ceil(double) int floor(double) double cos(double) double sin(double) double tan(double) double exp(double) double log(double) double log10(double) Renvoie la valeur absolue de l'entier i Renvoie l'entier immédiatement supérieur Renvoie l'entier immédiatement inférieur Renvoie le cosinus Renvoie le sinus Renvoie la tangente Elève e à la puissance donnée en paramètre Renvoie le logarithme népérien du nombre spécifié Renvoie le logarithme décimal du nombre spécifié double pow(double, double) Elève le premier nombre à la puissance indiquée par le second double sqrt(double) Renvoie la racine carrée de d III.3.2. Fichier string.h : Manipulation de chaînes de caractères. Toute chaîne doit être terminée par le caractère nul '\0'. strcmp(char*, char*) Comparaison lexicographique de 2 chaînes de caractères, renvoie un nombre négatif si la première est avant la seconde, positif si la première est après la seconde et nul si les chaînes sont identiques char* strcat(char*, char*) Concatène la seconde chaîne à la chaîne première char* strcpy(char*, char*) Copie la chaîne s2 dans la chaîne s1 int strlen(s) Renvoie la longueur de la chaîne donnée en paramètre III.3.3. Fichier ctype.h : Fonctions testant la nature d'un caractère. Elles renvoient une valeur non nulle si le test est positif, 0 sinon. int isalnum(c) Teste si c est un caractère alphanumérique Informatique Générale Langage C 35 Isabelle Ferrané

36 int isalpha(char) caractère alphabétique int isascii(char) code ascii int isdigit(char) chiffre décimal int isodigit(char chiffre octal int isxdigit(char) chiffre hexadécimal int islower(char) lettre minuscule int isupper(char) lettre majuscule int ispunct(char) caractère de ponctuation int isspace(char) caractère d'espacement int isprint(char) Teste si c est un caractère imprimable int toascii(char) Convertit le caractère en son code ascii int tolower(char) Convertit la lettre en minuscule int toupper(char) Convertit la lettre en majuscule III.3.4. Fichier stdlib.h III Fonctions de gestion de la mémoire dynamique void * correspond à un pointeur générique c'est-à-dire à un pointeur dont le type est déterminé ultérieurement en fonction du type du paramètre passé. size_t est une type prédéfini dans cette bibliothèque et correspond à tout type d'entier. void *malloc(size_t) Alloue un emplacement mémoire centrale correspondant au nombre d'octets indiqué en paramètre et renvoie l'adresse du début de la zone allouée (pointeur générique void * => conversion nécessaire en pointeur sur le type de donnée allouée) void *calloc(size_t, size_t) Alloue la place mémoire nécessaire pour stocker un tableau correspondant au nombre d'éléments indiqué par le premier paramètre, chaque élément ayant la taille indiquée par le second paramètre. Renvoie l'adresse du début de la zone allouée (pointeur générique void * => conversion nécessaire en pointeur sur le type de donnée allouée) void *realloc(void *, size_t) Informatique Générale Langage C 36 Isabelle Ferrané

37 Change la taille de la zone désignée par l'adresse fournie en paramètre en réallouant le nombre d'octets indiqué par le second paramètre. Renvoie l'adresse du début de la zone allouée car celle-ci peut avoir changé suite à une problème de place. Attention s'il s'agit de réallouer la zone correspondant à un tableau, le second paramètre doit correspondre au nombre total d'octets de la nouvelle zone et non pas la taille d'un élément comme pour la fonction calloc. void free(void *ptr) Libère la zone mémoire débutant à l'adresse indiquée. III Autres fonctions : void exit(unsigned int) Termine le programme en fermant fichiers et buffers. Le code de retour du programme correspond à la valeur donnée en paramètre. int system(char*) Transmet une commande au système d'exploitation. Si la commande décrite par la chaîne s'est exécutée sans problème, la valeur retournée est nulle sinon -1. Un sous shell sh est lance pour exécuter cette commande int rand (void) Permet la génération d un nombre pseudo-aléatoire dans l intervalle 0 RAND_MAX (constante symbolique définie dans sdtlib.h). Pour que la suite générée varie, il est nécessaire d appeler la fonction srand pour initialiser le générateur. void srand (unsigned int) initialise la génération pseudo-aléatoire de nombres à partir de la valeur fournie en paramètre. III.3.5. Autres bibliothèques à connaître Informatique Générale Langage C 37 Isabelle Ferrané

38 curses.h : bibliothèque pour la manipulation de structures de données pseudo-graphiques «fenêtres» sur des terminaux alphanumériques. dirent.h : bibliothèque de fonctions de gestion des répertoires erreno.h : gestion des erreurs time.h : gestion du temps. IV- La compilation séparée et l utilitaire MAKE IV-1. Compilation séparée Cette notion est liée à celle de programmation modulaire qui consiste à concevoir une application comme une collection de modules plus ou moins autonomes. Module : ensemble d'objets (données et sous-programmes) relatifs à une même tâche. Certains objets définis dans un module donné peuvent être utilisés dans un autre module. On parle alors d'objets partageables. Un module correspond à une unité de compilation. Unité de compilation : partie de code écrite dans un langage donné et pouvant être compilée séparément. En langage C, une unité de compilation est constituée par un fichier source (fichier.c). Ainsi, un programme modulaire est constitué de plusieurs fichiers source. Chacun d'eux correspond à un module du programme et peut donc être compilé séparément. Tout objet partageable doit être défini dans un seul module et déclaré dans tout autre module l'utilisant (une déclaration de variable ou de fonction indique que l'objet utilisé existe mais est défini dans un autre module). Rôle de la compilation : construire un module objet (fichier.o) pour chaque module source faisant partie de l'application. Exemple de commande de compilation d'un module : gcc -c fic1.c Informatique Générale Langage C 38 Isabelle Ferrané

39 Module source fic1.c COMPILATION DU MODULE Module objet fic1.o Rôle de l'édition de liens : construire le fichier exécutable à partir de tous les modules objets composant l'application. L'exécutable est généré seulement si aucune erreur d'édition de liens n'est détectée ; c'est-à-dire si tous les objets utilisés sont définis une et une seule fois dans l'application. Exemple de commande d'édition de liens : gcc fic1.o fic2.o fic3.o MODULES OBJETS fic1.o fic2.o fic3.o EDITION DE LIENS PROGRAMME EXECUTABLE a.out Remarque : dans toute application en langage C, il ne peut y avoir qu'une seule fonction principale main. Celle-ci doit donc se trouver dans un seul des modules constituant l'application. Attention!! : Ne pas confondre compilation séparée et inclusion de fichier. IV-2. L'utilitaire MAKE Cet utilitaire permet d'automatiser le processus de compilation séparée d'un programme modulaire. Informatique Générale Langage C 39 Isabelle Ferrané

40 Pour cela, il faut constituer un fichier de directives. Chaque directive permet la génération d'un module CIBLE à partir d'une liste de DEPENDANCES et d'une REGLE de construction. Syntaxe d'une directive : MODULE_CIBLE : LISTE_DES_DEPENDANCES REGLE_DE_CONSTRUCTION La liste des dépendances correspond à la liste des fichiers à partir desquels le module cible va être construit. La règle de construction correspond à la commande UNIX dont l'exécution doit produire le module cible. Attention!! : L'indentation de la règle fait partie de la syntaxe. Elle doit être décalée d'une tabulation. Exemple de directive : # generation du module objet mod.o à partir # du fichier source mod.c et des fichiers # donnees.h et macro.h inclus dans le # fichier source mod.c mod.o : mod.c donnees.h macro.h gcc -c mod.c Principe : Examen récursif des dépendances Lors du premier lancement, toutes les règles de construction sont exécutées et les modules cibles correspondants sont générés. Par la suite, seuls les modules ayant fait, directement ou indirectement, l'objet d'une mise à jour seront recréés. La prise en compte d'une directive débute par l'examen de la liste de dépendances. Si cette liste contient le nom d'un autre module cible, la directive associée est traitée en priorité (vérification récursive). Il suffit que l'un des fichiers de dépendances possède une date de mise à jour plus récente que celle du module cible auquel il est associé pour que celui-ci soit reconstruit à l'aide de la règle correspondante. Lancement de l'utilitaire sous Unix : make [options] cible_principale Informatique Générale Langage C 40 Isabelle Ferrané

41 Il faut spécifier le point d'entrée en donnant le nom du module à générer qui sera considéré comme la cible principale. La première directive traitée est alors celle associée à ce module. Si le fichier de directives a été nommé makefile il n'est pas nécessaire de mentionner ce nom lors du lancement de l'utilitaire car il s'agit du nom par défaut (1). Si un autre nom a été spécifié, généralement suffixé par mk (par exemple prog.mk), il faut utiliser l'option -f afin de préciser le nom exact du fichier de directives (2). Dans les exemples suivants, le point d'entrée est prog.out. (1) make prog.out (2) make -f prog.mk prog.out Attention!! : Ne pas confondre un fichier de directives avec un simple script shell contenant les commandes de compilation. Dans ce cas là, toutes les commandes sont exécutées, qu'il y ait besoin de le faire ou non (si un module n'a pas été modifié, il est inutile de le recompiler systématiquement). V- Bibliographie Pour compléter ce document vous pouvez vous référer à différents ouvrages : Les bases de l algorithmique : "Initiation à la programmation", Claude Delannoy - Eyrolles, 1997, ISBN : X. La programmation en langage C : "Le livre du C : premier langage", Claude Delannoy - Eyrolles, ISBN : "La programmation sous UNIX", Jean-Marie Rifflet, Ediscience International, 3 ème édition, 1986, ISBN : "Le langage C ANSI", Philippe Drix, Dunod Informatiques, 3 ème édition, 1997, ISBN : La programmation en langage C Exercices corrigés : "Exercices en Langage C", Claude Delannoy, Eyrolles, 3 ème édition, 1995, ISBN : "Programmation en C - Cours et problèmes", Byron S Gottfried, Série Schaum - Editions Ediscience International, Mc Graw Hill 1993, ISBN : Informatique Générale Langage C 41 Isabelle Ferrané

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

Licence ST Université Claude Bernard Lyon I LIF1 : Algorithmique et Programmation C Bases du langage C 1 Conclusion de la dernière fois Introduction de l algorithmique générale pour permettre de traiter

Plus en détail

Dans le chapitre 1, nous associions aux fichiers ouverts des descripteurs de fichiers par lesquels nous accédions aux fichiers.

Dans le chapitre 1, nous associions aux fichiers ouverts des descripteurs de fichiers par lesquels nous accédions aux fichiers. I Présentation : Dans le chapitre 1, nous avons vu comment utiliser les appels-systèmes de bas niveau pour créer et accéder à des fichiers sur le disque. Nous avons notamment mis en évidence leur dépouillement

Plus en détail

Cours d Algorithmique-Programmation 2 e partie (IAP2): programmation 24 octobre 2007impérative 1 / 44 et. structures de données simples

Cours d Algorithmique-Programmation 2 e partie (IAP2): programmation 24 octobre 2007impérative 1 / 44 et. structures de données simples Cours d Algorithmique-Programmation 2 e partie (IAP2): programmation impérative et structures de données simples Introduction au langage C Sandrine Blazy - 1ère année 24 octobre 2007 Cours d Algorithmique-Programmation

Plus en détail

Programmation en langage C

Programmation en langage C Programmation en langage C Anne CANTEAUT INRIA - projet CODES B.P. 105 78153 Le Chesnay Cedex [email protected] http://www-rocq.inria.fr/codes/anne.canteaut/cours C 2 Table des matières 3 Table des

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

SUPPORT DE COURS. Langage C

SUPPORT DE COURS. Langage C Dpt Informatique 2010-2011 SUPPORT DE COURS Langage C Semestre 1 par : «CaDePe» Marie-Françoise Canut Marianne de Michiel André Péninou Table des Matières 1 Généralités...8 1.1 Introduction aux langages

Plus en détail

INITIATION AU LANGAGE C SUR PIC DE MICROSHIP

INITIATION AU LANGAGE C SUR PIC DE MICROSHIP COURS PROGRAMMATION INITIATION AU LANGAGE C SUR MICROCONTROLEUR PIC page 1 / 7 INITIATION AU LANGAGE C SUR PIC DE MICROSHIP I. Historique du langage C 1972 : naissance du C dans les laboratoires BELL par

Plus en détail

Le Langage C Version 1.2 c 2002 Florence HENRY Observatoire de Paris Université de Versailles [email protected]

Le Langage C Version 1.2 c 2002 Florence HENRY Observatoire de Paris Université de Versailles florence.henry@obspm.fr Le Langage C Version 1.2 c 2002 Florence HENRY Observatoire de Paris Université de Versailles [email protected] Table des matières 1 Les bases 3 2 Variables et constantes 5 3 Quelques fonctions indispensables

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

Info0101 Intro. à l'algorithmique et à la programmation. Cours 3. Le langage Java

Info0101 Intro. à l'algorithmique et à la programmation. Cours 3. Le langage Java Info0101 Intro. à l'algorithmique et à la programmation Cours 3 Le langage Java Pierre Delisle, Cyril Rabat et Christophe Jaillet Université de Reims Champagne-Ardenne Département de Mathématiques et Informatique

Plus en dé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

UE Programmation Impérative Licence 2ème Année 2014 2015

UE Programmation Impérative Licence 2ème Année 2014 2015 UE Programmation Impérative Licence 2 ème Année 2014 2015 Informations pratiques Équipe Pédagogique Florence Cloppet Neilze Dorta Nicolas Loménie [email protected] 2 Programmation Impérative

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

IN 102 - Cours 1. 1 Informatique, calculateurs. 2 Un premier programme en C

IN 102 - Cours 1. 1 Informatique, calculateurs. 2 Un premier programme en C IN 102 - Cours 1 Qu on le veuille ou non, les systèmes informatisés sont désormais omniprésents. Même si ne vous destinez pas à l informatique, vous avez de très grandes chances d y être confrontés en

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

Rappels Entrées -Sorties

Rappels Entrées -Sorties Fonctions printf et scanf Syntaxe: écriture, organisation Comportement Données hétérogènes? Gestion des erreurs des utilisateurs 17/11/2013 Cours du Langage C [email protected] ibrahimguelzim.atspace.co.uk

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

Chap III : Les tableaux

Chap III : Les tableaux Chap III : Les tableaux Dans cette partie, on va étudier quelques structures de données de base tels que : Les tableaux (vecteur et matrice) Les chaînes de caractères LA STRUCTURE DE TABLEAU Introduction

Plus en détail

Langage C. Patrick Corde. [email protected]. 22 juin 2015. Patrick Corde ( [email protected] ) Langage C 22 juin 2015 1 / 289

Langage C. Patrick Corde. Patrick.Corde@idris.fr. 22 juin 2015. Patrick Corde ( Patrick.Corde@idris.fr ) Langage C 22 juin 2015 1 / 289 Langage C Patrick Corde [email protected] 22 juin 2015 Patrick Corde ( [email protected] ) Langage C 22 juin 2015 1 / 289 Table des matières I 1 Présentation du langage C Historique Intérêts

Plus en détail

INITIATION A LA PROGRAMMATION

INITIATION A LA PROGRAMMATION 2004-2005 Université Paris Dauphine IUP Génie Mathématique et Informatique INITIATION A LA PROGRAMMATION PROCEDURALE, A L'ALGORITHMIQUE ET AUX STRUCTURES DE DONNEES PAR LE LANGAGE C Maude Manouvrier La

Plus en détail

Initiation à la programmation en Python

Initiation à la programmation en Python I-Conventions Initiation à la programmation en Python Nom : Prénom : Une commande Python sera écrite en caractère gras. Exemples : print 'Bonjour' max=input("nombre maximum autorisé :") Le résultat de

Plus en détail

UE C avancé cours 1: introduction et révisions

UE C avancé cours 1: introduction et révisions Introduction Types Structures de contrôle Exemple UE C avancé cours 1: introduction et révisions Jean-Lou Desbarbieux et Stéphane Doncieux UMPC 2004/2005 Introduction Types Structures de contrôle Exemple

Plus en détail

UEO11 COURS/TD 1. nombres entiers et réels codés en mémoire centrale. Caractères alphabétiques et caractères spéciaux.

UEO11 COURS/TD 1. nombres entiers et réels codés en mémoire centrale. Caractères alphabétiques et caractères spéciaux. UEO11 COURS/TD 1 Contenu du semestre Cours et TDs sont intégrés L objectif de ce cours équivalent a 6h de cours, 10h de TD et 8h de TP est le suivant : - initiation à l algorithmique - notions de bases

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

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

Cours 1 : Introduction. Langages objets. but du module. contrôle des connaissances. Pourquoi Java? présentation du module. Présentation de Java

Cours 1 : Introduction. Langages objets. but du module. contrôle des connaissances. Pourquoi Java? présentation du module. Présentation de Java Langages objets Introduction M2 Pro CCI, Informatique Emmanuel Waller, LRI, Orsay présentation du module logistique 12 blocs de 4h + 1 bloc 2h = 50h 1h15 cours, 45mn exercices table, 2h TD machine page

Plus en détail

TP n 2 Concepts de la programmation Objets Master 1 mention IL, semestre 2 Le type Abstrait Pile

TP n 2 Concepts de la programmation Objets Master 1 mention IL, semestre 2 Le type Abstrait Pile TP n 2 Concepts de la programmation Objets Master 1 mention IL, semestre 2 Le type Abstrait Pile Dans ce TP, vous apprendrez à définir le type abstrait Pile, à le programmer en Java à l aide d une interface

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

INF 321 : mémento de la syntaxe de Java

INF 321 : mémento de la syntaxe de Java INF 321 : mémento de la syntaxe de Java Table des matières 1 La structure générale d un programme 3 2 Les composants élémentaires de Java 3 2.1 Les identificateurs.................................. 3 2.2

Plus en détail

Cours de programmation avancée. Le langage C. Université du Luxembourg 2005 2006

Cours de programmation avancée. Le langage C. Université du Luxembourg 2005 2006 Université du Luxembourg 2005 2006 Cours de programmation avancée. Le langage C Sébastien Varrette Version : 0.4 Nicolas Bernard 2 Table des matières

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

Programmation C. J.-F. Lalande. 15 novembre 2012

Programmation C. J.-F. Lalande. 15 novembre 2012 Programmation C J.-F. Lalande novembre 0 Ce cours est mis à disposition par Jean-François Lalande selon les termes de la licence Creative Commons Attribution - Pas d Utilisation Commerciale - Partage à

Plus en détail

Initiation. àl algorithmique et à la programmation. en C

Initiation. àl algorithmique et à la programmation. en C Initiation àl algorithmique et à la programmation en C Initiation àl algorithmique et à la programmation en C Cours avec 129 exercices corrigés Illustration de couverture : alwyncooper - istock.com Dunod,

Plus en dé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

Claude Delannoy. 3 e édition C++

Claude Delannoy. 3 e édition C++ Claude Delannoy 3 e édition Exercices Exercices C++ en en langage langage delc++ titre 4/07/07 15:19 Page 2 Exercices en langage C++ AUX EDITIONS EYROLLES Du même auteur C. Delannoy. Apprendre le C++.

Plus en détail

Compression de Données - Algorithme de Huffman Document de Conception

Compression de Données - Algorithme de Huffman Document de Conception ROLLET Samuel SALLE Jennifer Compression de Données - Algorithme de Huffman Document de Conception Projet d'algorithmique et Structure des Données 1 SOMMAIRE 1. Domaine d application....4 1.1 Objectifs

Plus en détail

Cours d introduction à l informatique. Partie 2 : Comment écrire un algorithme? Qu est-ce qu une variable? Expressions et instructions

Cours d introduction à l informatique. Partie 2 : Comment écrire un algorithme? Qu est-ce qu une variable? Expressions et instructions Cours d introduction à l informatique Partie 2 : Comment écrire un algorithme? Qu est-ce qu une variable? Expressions et instructions Qu est-ce qu un Une recette de cuisine algorithme? Protocole expérimental

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 [email protected] «v0.1 Rappel Programmation modulaire (1/2) Le découpage d'un programme en sous-programmes est appelée programmation

Plus en détail

Chapitre 1 : La gestion dynamique de la mémoire

Chapitre 1 : La gestion dynamique de la mémoire Chapitre 1 : La gestion dynamique de la mémoire En langage C un programme comporte trois types de données : Statiques; Automatiques ; Dynamiques. Les données statiques occupent un emplacement parfaitement

Plus en détail

Centre CPGE TSI - Safi 2010/2011. Algorithmique et programmation :

Centre CPGE TSI - Safi 2010/2011. Algorithmique et programmation : Algorithmique et programmation : STRUCTURES DE DONNÉES A. Structure et enregistrement 1) Définition et rôle des structures de données en programmation 1.1) Définition : En informatique, une structure de

Plus en détail

Anis ASSÈS Mejdi BLAGHGI Mohamed Hédi ElHajjej Mohamed Salah Karouia

Anis ASSÈS Mejdi BLAGHGI Mohamed Hédi ElHajjej Mohamed Salah Karouia Ministère de l Enseignement Supérieur, de la Recherche Scientifique et de la Technologie Direction Générale des Etudes Technologiques Institut Supérieur des Etudes Technologiques de Djerba SUPPORT DE COURS

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

Programmation Classique en langage C

Programmation Classique en langage C DI GALLO Frédéric Programmation Classique en langage C Cours du Cycle d Approfondissement CNAM ANGOULEME 2000-2001 DI GALLO Frédéric Page 1 01/04/01 PROGRAMMATION CLASSIQUE : LANGAGE C DI GALLO Frédéric

Plus en détail

Les fichiers. Chapitre 4

Les fichiers. Chapitre 4 Chapitre 4 Les fichiers Jusqu à maintenant tous les programmes que nous avons conçus travaillaient sur des données qui étaient perdues après chaque session de travail. On peut cependant, c est bien naturel,

Plus en détail

BTS IRIS Cours et Travaux Pratiques. Programmation C. A. Lebret, TSIRIS, Lycée Diderot, 1995/06. en conformité avec le référentiel du BTS IRIS

BTS IRIS Cours et Travaux Pratiques. Programmation C. A. Lebret, TSIRIS, Lycée Diderot, 1995/06. en conformité avec le référentiel du BTS IRIS BTS IRIS Cours et Travaux Pratiques Programmation C A. Lebret, TSIRIS, Lycée Diderot, 1995/06 en conformité avec le référentiel du BTS IRIS Activité Codage et Réalisation Tâches T3.3, T3.4 et T3.5 Temps

Plus en détail

Langage Éric Guérin 5 octobre 2010

Langage Éric Guérin 5 octobre 2010 Langage Éric Guérin 5 octobre 2010 Langage C TABLE DES MATIÈRES Table des matières 1 Introduction 7 1.1 Historique........................................... 7 1.2 Architecture matérielle....................................

Plus en détail

Brefs rappels sur la pile et le tas (Stack. / Heap) et les pointeurs

Brefs rappels sur la pile et le tas (Stack. / Heap) et les pointeurs Brefs rappels sur la pile et le tas (Stack / Heap) et les pointeurs (exemples en C) v1.11 - Olivier Carles 1 Pile et Tas Mémoire allouée de manière statique Mémoire Allouée Dynamiquement variables locales

Plus en détail

V- Manipulations de nombres en binaire

V- Manipulations de nombres en binaire 1 V- Manipulations de nombres en binaire L ordinateur est constitué de milliards de transistors qui travaillent comme des interrupteurs électriques, soit ouverts soit fermés. Soit la ligne est activée,

Plus en détail

Conventions d écriture et outils de mise au point

Conventions d écriture et outils de mise au point Logiciel de base Première année par alternance Responsable : Christophe Rippert [email protected] Introduction Conventions d écriture et outils de mise au point On va utiliser dans cette

Plus en détail

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

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

Plus en détail

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

Structure d un programme et Compilation Notions de classe et d objet Syntaxe

Structure d un programme et Compilation Notions de classe et d objet Syntaxe Cours1 Structure d un programme et Compilation Notions de classe et d objet Syntaxe POO 1 Programmation Orientée Objet Un ensemble d objet qui communiquent Pourquoi POO Conception abstraction sur les types

Plus en détail

Algorithmique & Langage C IUT GEII S1. Notes de cours (première partie) cours_algo_lgc1.17.odp. Licence

Algorithmique & Langage C IUT GEII S1. Notes de cours (première partie) cours_algo_lgc1.17.odp. Licence Licence Algorithmique & Langage C Paternité - Pas d'utilisation Commerciale Partage des Conditions Initiales à l'identique 2.0 France Vous êtes libres : * de reproduire, distribuer et communiquer cette

Plus en détail

Le langage C. Introduction, guide de reference

Le langage C. Introduction, guide de reference Le langage C Introduction, guide de reference Ce document est une présentation du langage de programmation C, de sa syntaxe et de ses spécificités. Il est destiné essentiellement à servir de mémo-guide

Plus en détail

Cours 1 : Introduction Ordinateurs - Langages de haut niveau - Application

Cours 1 : Introduction Ordinateurs - Langages de haut niveau - Application Université de Provence Licence Math-Info Première Année V. Phan Luong Algorithmique et Programmation en Python Cours 1 : Introduction Ordinateurs - Langages de haut niveau - Application 1 Ordinateur Un

Plus en détail

Introduction à la programmation orientée objet, illustrée par le langage C++ Patrick Cégielski [email protected]

Introduction à la programmation orientée objet, illustrée par le langage C++ Patrick Cégielski cegielski@u-pec.fr Introduction à la programmation orientée objet, illustrée par le langage C++ Patrick Cégielski [email protected] Mars 2002 Pour Irène et Marie Legal Notice Copyright c 2002 Patrick Cégielski Université

Plus en détail

COMPARAISONDESLANGAGESC, C++, JAVA ET

COMPARAISONDESLANGAGESC, C++, JAVA ET REPUBLIQUE DU BENIN *******@******* MINISTERE DE L ENSEIGNEMENT SUPERIEUR ET DE LA RECHERCHE SCIENTIFIQUE(MESRS) *******@******* UNIVERSITE D ABOMEY CALAVI(UAC) *******@******* ECOLE POLYTECHNIQUE D ABPOMEY

Plus en détail

Cours d Algorithmique et de Langage C 2005 - v 3.0

Cours d Algorithmique et de Langage C 2005 - v 3.0 Cours d Algorithmique et de Langage C 2005 - v 3.0 Bob CORDEAU [email protected] Mesures Physiques IUT d Orsay 15 mai 2006 Avant-propos Avant-propos Ce cours en libre accès repose sur trois partis pris

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

Introduction à MATLAB R

Introduction à MATLAB R Introduction à MATLAB R Romain Tavenard 10 septembre 2009 MATLAB R est un environnement de calcul numérique propriétaire orienté vers le calcul matriciel. Il se compose d un langage de programmation, d

Plus en détail

LES TYPES DE DONNÉES DU LANGAGE PASCAL

LES TYPES DE DONNÉES DU LANGAGE PASCAL LES TYPES DE DONNÉES DU LANGAGE PASCAL 75 LES TYPES DE DONNÉES DU LANGAGE PASCAL CHAPITRE 4 OBJECTIFS PRÉSENTER LES NOTIONS D ÉTIQUETTE, DE CONS- TANTE ET DE IABLE DANS LE CONTEXTE DU LAN- GAGE PASCAL.

Plus en détail

INF111. Initiation à la programmation impérative en C http://ama.liglab.fr/ amini/cours/l1/inf111/ Massih-Reza Amini

INF111. Initiation à la programmation impérative en C http://ama.liglab.fr/ amini/cours/l1/inf111/ Massih-Reza Amini Initiation à la programmation impérative en C http://ama.liglab.fr/ amini/cours/l1// Massih-Reza Amini Université Joseph Fourier Laboratoire d Informatique de Grenoble 2/52 Introduction Structures de contrôle

Plus en détail

Généralités sur le Langage Java et éléments syntaxiques.

Généralités sur le Langage Java et éléments syntaxiques. Généralités sur le Langage Java et éléments syntaxiques. Généralités sur le Langage Java et éléments syntaxiques....1 Introduction...1 Genéralité sur le langage Java....1 Syntaxe de base du Langage...

Plus en détail

REPUBLIQUE ALGERIENNE DEMOCRATIQUE ET POPULAIRE UNIVERSITE M HAMED BOGARA DE BOUMERDES

REPUBLIQUE ALGERIENNE DEMOCRATIQUE ET POPULAIRE UNIVERSITE M HAMED BOGARA DE BOUMERDES REPUBLIQUE ALGERIENNE DEMOCRATIQUE ET POPULAIRE MINISTERE DE L ENSEIGNEMENT SUPERIEUR ET DE LA RECHERCHE SCIENTIFIQUE UNIVERSITE M HAMED BOGARA DE BOUMERDES FACULTE DES SCIENCES - DEPARTEMENT PHYSIQUE

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

Le Langage C Licence Professionnelle Qualité Logiciel Pr. Mouad BEN MAMOUN [email protected] Année universitaire 2011/2012

Le Langage C Licence Professionnelle Qualité Logiciel Pr. Mouad BEN MAMOUN ben_mamoun@fsr.ac.ma Année universitaire 2011/2012 Le Langage C Licence Professionnelle Qualité Logiciel Pr. Mouad BEN MAMOUN [email protected] Année universitaire 2011/2012 2011/2012 Pr. Ben Mamoun 1 Plan du cours (1) 1. Introduction 2. Types, opérateurs

Plus en détail

MICROINFORMATIQUE NOTE D APPLICATION 1 (REV. 2011) ARITHMETIQUE EN ASSEMBLEUR ET EN C

MICROINFORMATIQUE NOTE D APPLICATION 1 (REV. 2011) ARITHMETIQUE EN ASSEMBLEUR ET EN C Haute Ecole d Ingénierie et de Gestion Du Canton du Vaud MICROINFORMATIQUE NOTE D APPLICATION 1 (REV. 2011) ARITHMETIQUE EN ASSEMBLEUR ET EN C Programmation en mode simulation 1. DOCUMENTS DE RÉFÉRENCE...

Plus en détail

Introduction au Langage de Programmation C

Introduction au Langage de Programmation C Faculté Polytechnique de Mons Service d'informatique Introduction au Langage de Programmation C Mohammed Benjelloun 1 ère Candidature Année académique 2003-2004 Avant-propos Ces notes permettent de se

Plus en détail

Algorithmes et Programmes. Introduction à l informatiquel. Cycle de vie d'un programme (d'un logiciel) Cycle de vie d'un programme (d'un logiciel)

Algorithmes et Programmes. Introduction à l informatiquel. Cycle de vie d'un programme (d'un logiciel) Cycle de vie d'un programme (d'un logiciel) Algorithmes et Programmes Introduction à l informatiquel! Vie d'un programme! Algorithme! Programmation : le langage! Exécution et test des programmes Chapitre : Algorithmes et Programmes 2 Cycle de vie

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

ALGORITHMIQUE ET PROGRAMMATION En C

ALGORITHMIQUE ET PROGRAMMATION En C Objectifs ALGORITHMIQUE ET PROGRAMMATION Une façon de raisonner Automatiser la résolution de problèmes Maîtriser les concepts de l algorithmique Pas faire des spécialistes d un langage Pierre TELLIER 2

Plus en détail

Cours intensif Java. 1er cours: de C à Java. Enrica DUCHI LIAFA, Paris 7. Septembre 2009. [email protected]

Cours intensif Java. 1er cours: de C à Java. Enrica DUCHI LIAFA, Paris 7. Septembre 2009. Enrica.Duchi@liafa.jussieu.fr . Cours intensif Java 1er cours: de C à Java Septembre 2009 Enrica DUCHI LIAFA, Paris 7 [email protected] LANGAGES DE PROGRAMMATION Pour exécuter un algorithme sur un ordinateur il faut le

Plus en détail

Programmation Structurée en Langage C

Programmation Structurée en Langage C École Centrale Marseille Programmation Structurée en Langage C Stéphane Derrode Mathématique et Informatique Révision 2.5, 2006. Table des matières 1 En guise d'introduction... 7 1.1 Quelques repères

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 [email protected] Février

Plus en détail

Algorithmique avec Algobox

Algorithmique avec Algobox Algorithmique avec Algobox 1. Algorithme: Un algorithme est une suite d instructions qui, une fois exécutée correctement, conduit à un résultat donné Un algorithme doit contenir uniquement des instructions

Plus en détail

Représentation des Nombres

Représentation des Nombres Chapitre 5 Représentation des Nombres 5. Representation des entiers 5.. Principe des représentations en base b Base L entier écrit 344 correspond a 3 mille + 4 cent + dix + 4. Plus généralement a n a n...

Plus en détail

Algorithme. Table des matières

Algorithme. Table des matières 1 Algorithme Table des matières 1 Codage 2 1.1 Système binaire.............................. 2 1.2 La numérotation de position en base décimale............ 2 1.3 La numérotation de position en base binaire..............

Plus en détail

Recherche dans un tableau

Recherche dans un tableau Chapitre 3 Recherche dans un tableau 3.1 Introduction 3.1.1 Tranche On appelle tranche de tableau, la donnée d'un tableau t et de deux indices a et b. On note cette tranche t.(a..b). Exemple 3.1 : 3 6

Plus en détail

Méthodes de programmation systèmes UE n NSY103. Notes de cours. Nombre d'heures : 55h (~18 + 1 cours de 3 heures)

Méthodes de programmation systèmes UE n NSY103. Notes de cours. Nombre d'heures : 55h (~18 + 1 cours de 3 heures) Méthodes de programmation systèmes UE n NSY103 Notes de cours Code de l UE : NSY103 Titre de la formation : Méthodes de programmation systèmes Ouvert : Ouvert Type de diplôme : Unité de valeur CNAM. Nombre

Plus en détail

Programmer en JAVA. par Tama ([email protected]( [email protected])

Programmer en JAVA. par Tama (tama@via.ecp.fr( tama@via.ecp.fr) Programmer en JAVA par Tama ([email protected]( [email protected]) Plan 1. Présentation de Java 2. Les bases du langage 3. Concepts avancés 4. Documentation 5. Index des mots-clés 6. Les erreurs fréquentes

Plus en détail

Programmation en C. École Nationale Supérieure de Techniques Avancées. Pierre-Alain Fouque et David Pointcheval

Programmation en C. École Nationale Supérieure de Techniques Avancées. Pierre-Alain Fouque et David Pointcheval École Nationale Supérieure de Techniques Avancées Programmation en C Pierre-Alain Fouque et David Pointcheval E-mail : [email protected] Web : http://www.di.ens.fr/~fouque/ Table des matières

Plus en détail

TP 1. Prise en main du langage Python

TP 1. Prise en main du langage Python TP. Prise en main du langage Python Cette année nous travaillerons avec le langage Python version 3. ; nous utiliserons l environnement de développement IDLE. Étape 0. Dans votre espace personnel, créer

Plus en détail

Programmation C++ (débutant)/instructions for, while et do...while

Programmation C++ (débutant)/instructions for, while et do...while Programmation C++ (débutant)/instructions for, while et do...while 1 Programmation C++ (débutant)/instructions for, while et do...while Le cours du chapitre 4 : le for, while et do...while La notion de

Plus en détail

Notes du cours 4M056 Programmation en C et C++ Vincent Lemaire et Damien Simon

Notes du cours 4M056 Programmation en C et C++ Vincent Lemaire et Damien Simon Notes du cours 4M056 Programmation en C et C++ Vincent Lemaire et Damien Simon 13 janvier 2015 2 Table des matières Organisation générale du cours 7 1 Notions générales d algorithmique et de programmation

Plus en détail

STAGE IREM 0- Premiers pas en Python

STAGE IREM 0- Premiers pas en Python Université de Bordeaux 16-18 Février 2014/2015 STAGE IREM 0- Premiers pas en Python IREM de Bordeaux Affectation et expressions Le langage python permet tout d abord de faire des calculs. On peut évaluer

Plus en détail

INTRODUCTION A JAVA. Fichier en langage machine Exécutable

INTRODUCTION A JAVA. Fichier en langage machine Exécutable INTRODUCTION A JAVA JAVA est un langage orienté-objet pur. Il ressemble beaucoup à C++ au niveau de la syntaxe. En revanche, ces deux langages sont très différents dans leur structure (organisation du

Plus en détail

Représentation d un entier en base b

Représentation d un entier en base b Représentation d un entier en base b 13 octobre 2012 1 Prérequis Les bases de la programmation en langage sont supposées avoir été travaillées L écriture en base b d un entier est ainsi défini à partir

Plus en détail

SYSTÈME DE GESTION DE FICHIERS

SYSTÈME DE GESTION DE FICHIERS SYSTÈME DE GESTION DE FICHIERS - DISQUE 1 Les couches logiciels réponse requête Requêtes E/S Système E/S Pilote E/S Interruptions utilisateur traitement S.E. commandes S.E. S.E. matériel Contrôleur E/S

Plus en détail

Plan du cours. Historique du langage http://www.oracle.com/technetwork/java/index.html. Nouveautés de Java 7

Plan du cours. Historique du langage http://www.oracle.com/technetwork/java/index.html. Nouveautés de Java 7 Université Lumière Lyon 2 Faculté de Sciences Economiques et Gestion KHARKIV National University of Economic Introduction au Langage Java Master Informatique 1 ère année Julien Velcin http://mediamining.univ-lyon2.fr/velcin

Plus en détail

Utilisation d objets : String et ArrayList

Utilisation d objets : String et ArrayList Chapitre 6 Utilisation d objets : String et ArrayList Dans ce chapitre, nous allons aborder l utilisation d objets de deux classes prédéfinies de Java d usage très courant. La première, nous l utilisons

Plus en détail

Programmation système de commandes en C

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

Plus en détail

Langages et Concepts de Programmation Introduction à la programmation en langage C

Langages et Concepts de Programmation Introduction à la programmation en langage C Langages et Concepts de Programmation Introduction à la programmation en langage C Cours 1A 2013-2014 Jean-Jacques Girardot, Marc Roelens [email protected], [email protected] Septembre 2013 École Nationale

Plus en détail

Une version javascript sera disponible directement dans le cours prochainement.

Une version javascript sera disponible directement dans le cours prochainement. Author : Cédric Vanconingsloo Ce cours est principalement axé sur la compréhension du fonctionnement d'un ordinateur et l'étude du seul langage qu'il connaisse, le binaire. De ce fait, le cours est relativement

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

Cours Informatique Master STEP

Cours Informatique Master STEP Cours Informatique Master STEP Bases de la programmation: Compilateurs/logiciels Algorithmique et structure d'un programme Programmation en langage structuré (Fortran 90) Variables, expressions, instructions

Plus en détail

Cours d Informatique

Cours d Informatique Cours d Informatique 1ère année SM/SMI 2007/2008, Info 2 Département de Mathématiques et d Informatique, Université Mohammed V [email protected] [email protected] 2007/2008 Info2, 1ère année SM/SMI 1

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 [email protected] Environnement Les programmes peuvent être exécutés dans des

Plus en détail

Algorithmique et programmation : les bases (VBA) Corrigé

Algorithmique et programmation : les bases (VBA) Corrigé PAD INPT ALGORITHMIQUE ET PROGRAMMATION 1 Cours VBA, Semaine 1 mai juin 2006 Corrigé Résumé Ce document décrit l écriture dans le langage VBA des éléments vus en algorithmique. Table des matières 1 Pourquoi

Plus en détail