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

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

Download "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."

Transcription

1 Le langage C Centrale Réseaux Mardi 15 décembre 2009

2 Sommaire

3 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), le langage le plus utilisé. Le C a l avantage d être : léger concis bas niveau portable haut niveau Le C est un langage compilé, ce qui lui permet d être très performant.

4 Compiler un programme Plus facile à utiliser sur un UNIX (Linux, MacOSX) : On écrit son programme avec son éditeur préféré La compilation se fait en ligne de commande avec gcc 1 : gcc monfichier.c -o monprog Sous Windows, il faut installer un IDE comme Visual Studio ou Code : :Blocks. 1. GNU C Compiler/ GNU Compiler Collection

5 Au programme :

6 Notre premier programme en C 1 #include <stdio.h> 2 int main(int argc, char** argv) { 3 printf("hello, World!\\n"); 4 return 0; 5 } Les instructions se terminent par un point-virgule Les blocs d instructions sont encadrés par des accolades Les commentaires sont encadrés par /* et */ Les commentaires courts commencent par //

7 Notre premier programme en C 1 #include <stdio.h> 2 int main(int argc, char** argv) { 3 /* Voici un commentaire sur plusieurs lignes 4 qui se continue ici : notre prermier programme en C */ 5 printf("hello, World!\n"); // On affiche du texte 6 return 0; 7 } Compilez et exécutez le programme hello.c ; c est trop ouf, hein!

8 Les variables Les variables en C sont typées et il faut les déclarer au compilateur. Il existe plusieurs types de base : Caractère : char Nombre entier : int (integer) Nombre décimal : float (floating-point) Nombre décimal en double précision : double 1 /* Déclarations */ 2 char c; 3 int i; 4 float f; 5 /* Affectation */ 6 c= c ; 7 i=42; 8 f=3.4159; La déclaration permet au programme de réserver de la pour y stocker la variable.

9 Les types On peut varier les types grâce à des mots-clefs : signed/unsigned, short/long et double type signification octets Plage de valeurs (signed)char caractère à 127 unsigned char caractère non signé 1 0 à 255 short int entier court à unsigned short int entier court non signé 2 0 à int entier à unsigned int entier non signé 4 0 à long int entier long à unsigned long int entier long non signé 4 0 à float nombre à virgule flottante à double nombre en double précision à long long int entier long étendu à unsigned long long int entier long étendu 8 0 à long double nombre en double précision étendu Généralement, signed est implicite : un int est en fait un signed int. Généralement, un int fait 4 octets ; parfois (sur certaines architectures) seulement 2. On peut omettre int et écrire directement short, long ou long long

10 Utilisons 1 /* On peut déclarer plusieurs variables d un coup */ 2 int i, j, k, n; 3 /* Déclaration + Affectation = Initialisation*/ 4 char c= c ; 5 float f, g=0.001,h; 6 /*Les opérations arithmétiques */ 7 i = 3 ; j = 4 ; 8 k = (i + (j * (i - n))) ;// attention aux priorités 9 k = i / j ; // = 0 (division entière) 0 /*Les affectations combinées */ 1 k += i ; // équivaut à k = k+i 2 k *= j ; // équivaut à k = k*i 3 k++; // équivaut à k+=1;

11 Précautions à prendre Une variable non initialisée a une valeur aléatoire! 1 int i = 3, j = 4 ; 2 float f = 0.42, g = 1.2 ; 3 g = i + f ;// conversion implicite 4 g = (float) i / (float) j ; // conversion explicite 5 /* on parle aussi de cast ou de transtypage */ Attention à la priorité des opérateurs et à leur ordre d évaluation. Parfois le résultat n est pas défini (exemple : i++ = i++;)

12 Utiliser printf Printf permet d afficher du texte à l écran. 1 #include <stdio.h> // nécéssaire pour utiliser printf 2 int main (int argc, char** argv ) { 3 int i = 0, j = 3; 4 printf("j vaut %d et i vaut %d\n",j,i) 5 } On utilise %* pour afficher une variable %d pour afficher sous la forme d un entier %f pour addicher sous la forme d un flottant %c pour afficher sous la forme d un caractère

13 Lire et écrire On peut récupérer un caractère de l entrée avec getchar() 1 #include <stdio.h> 2 /* ce programme affiche à l écran ce qu on frappe au clavier */ 3 int main (int argc, char** argv ) { 4 char c; 5 c = getchar(); 6 while (c!= EOF) { 7 printf("%c",c); 8 c = getchar(); 9 } 0 }

14 Conditions et valeur d une expression Les instructions sont évaluées, c est à dire qu elles ont une valeur. 1 int a,b; 2 a=(b=3); Toute valeur nulle est fausse. Les autres valeurs sont vraies. Pour spécifier des conditions on utilise : Les opérateurs de comparaison sont ==,!=, <,>,<=,<= Les opérateurs logiques : &&,,! On peut combiner valeurs de retour et opérateurs logiques : 1 int a=1,b=3; 2 a = (((b == 3) (a!= 1)) &&!(( b = 42) > 12)); 3 /* a vaut maintenant 0 et b 42 */

15 Les instructions if / else : accolades (obligatoire) et indentation (c est plus lisible) Les structure de choix : if, if/else ou if/else if/.../else. 1 if (i==3 && j < 3) { 2 // instructions 3 } else if (isnormal(k)) { 4 // instructions 5 } else { 6 // instructions 7 }

16 La boucle for 1 int i ; 2 for (i = 0 ; i < 100 ; i++) { 3 // instructions 4 } Les 3 instructions sont arbitraires : La première est effectuée une seule fois, La 2eme est effectuée au début de chaque itération. Si sa valeur est nulle la boucle s arrête La 3eme est effectuée au début de chaque itération.

17 La boucle while Les boucles while et for sont interchangeables (en théorie). Le mot-clef break permet de quitter la boucle. 1 int i ; 2 while (i!= 0) { 3 // instructions 4 if (erreur) { 5 break; 6 } 7 } 1 #include <stdio.h> 2 int main(int argc, char** argv) { 3 char c; 4 while ((c=getchar())!=eof) { 5 printf("%c",c); 6 } 7 }

18 Fonctions et variables 1 #include <stdio.h> 2 int f(int x) { 3 int b=42; 4 return x+42; 5 } 6 7 int main (int argc char** argv) { 8 int a=3; 9 int b; 0 b=f(a); 1 printf("%d",b) 2 } Les variables sont locales à un bloc et n existent pas à l extérieur.

19 Prototypes et fonctions Comme, les fonctions sont déclarées avec le type de leur valeur de retour et leurs arguments (prototype) Le type void est utilisé pour les fonctions sans paramètre ou qui ne retournent rien. 1 int fonction1(int param1, float param2); 2 float fonction2(double, unsigned char); 3 void fonction3 (int); 4 char fonction4(void); On ne peut pas déclarer une fonction dans une autre fonction

20 Les fonctions : quelques détails Les fonctions peuvent être récursives 1 int factorielle(int n) { 2 if (n == 1 n == 0) { 3 return 1; 4 } else { 5 return n * factorielle(n-1); 6 } 7 } Les arguments peuvent subir une conversion implicite Une erreur de compilation se produit si un cast est requis 1 double carre(double l){ 2 return l*l 3 } 4 //... plus tard, dans le main... 5 int a = 3; 6 carre(a); // a est converti en double

21 Un tableau est une suite de variables de même type. 1 int a[10]; /* crée un tableau de 10 entiers 2 on y accède par a[0], a[1]... a [9] */ 3 a[4] = 42 ; 4 int b[4] = {12, 3, 4, 17} ; // initialise le tableau Une chaîne est en fait un tableau de char! Mais attention au \0 final! 1 char s[5]; // crée un tableau de 5 char 2 s = "plop"; 3 // s contient p, l, o, p, \0 4 s = "meh"; 5 // s contient m, e, h, \0, une valeur inconnue

22 Au programme :

23 Qu est ce que la La est un grand tableau numéroté. Chaque case fait 1 octet Déclarer une variable lui réserve une place en 1 unsigned int a; // les blocs 2454 à 2457 sont réservés pour a 2 a = 1027 ; Maintenant la ressemble à ça :

24 Qu est ce qu un pointeur? L opérateur & donne l adresse d une variable 1 printf("%d",&a) ; // affiche l adresse de a Un pointeur est une variable qui contient l adresse d une autre variable. 1 p = &a ; // p pointe sur a L opérateur inverse est * (déréférencement) *p peut être utilisé à la place de a n importe où 1 a = 3 ; p = &a ; 2 *p += 40 ;// a vaut maintenant 42 3 b = f(*p) ;// 42 est passé en argument de f

25 Un peu plus près des * Les pointeurs doivent être déclarés en fonction du type de la variable sur laquelle ils pointent 1 int a ; double b ; unsigned char c ; 2 int * pa; // un pointeur sur int 3 double * pb = &b; //initialisation 4 unsigned char * pc = NULL ; // pointeur nul Pointeur non initialisé = DANGER! 1 //attention aux déclarations multiples 2 int *p,*q ;// p et q sont des int* ;

26 Exemple : le passage par référence Ce que je veux : une fonction swap(a,b) qui échange a et b. 1 void swap(int * pa,int * pb) { 2 int c = *pa; 3 *pa = *pb; 4 *pb = c; 5 } 6 //... plus tard... 7 int a = 12, b = 42 ; 8 swap(&a,&b); 9 /* maintenant a vaut 42 et b 12 */ Meilleures performances quand on passe de grosses donées

27 Les pointeurs et les tableaux Les pointeurs et les tableaux sont très liés! Un exemple : 1 short[10] a ; 2 short * p = &(a[0]) ; 3 int i; 4 for (i = 0 ; i<10 ; i++) { 5 a[i] = 3*i ; 6 printf("%d",*(p+i)); 7 // *(p+i) et a[i] désignent le même élément 8 } Dans la : a[0] a[0] a[1] a[1] a[2] a[2] p (p+1) (p+2)

28 Application : les chaînes de caractères Une chaîne de caractère peut être représentée par un char* Un exemple : 1 char* str = "Une chaine de caracteres"; 2 void stringcopy(char * src, char * dest); 3 while( (*dest = *src)!= \0 ) { 4 dest++; 5 src++; 6 }

29 Les pointeurs génériques On utilise le type void* pour représenter un pointeur générique. Il est compté comme un pointeur sur un objet de 1 octet pour l arithmétique Il faut le caster pour s en servir Son usage : à limiter

30 Attention aux pointeurs! On ne peut pas lire ou écrire n importe où dans la! Dans le meilleur des cas : segmentation fault Dans le pire des cas : données corrompues Attention aux casts foireux.

31 Les structures Une structure est un rassemblement de plusieurs variables Les variables peuvent être de type différents 1 // déclaration de la structure 2 struct Pays { 3 char* nom; 4 long nbhabitants; 5 double superficie 6 } 7 // déclaration d une instance de la structure 8 struct Pays monpays; 9 // initialisation; 0 monpays = {"France", ,675417} 1 //accès à une valeur 2 printf(monpays.nom); 3 printf(" : un pays de %d habitants",monpays.nbhabitants);

32 Les pointeurs de structure 1 void naissance(struct Pays * unpays){ 2 // attention aux parentheses 3 (*unppays).nbhabitants++; 4 } On peut écrire a->b au lieu de (*a).b On peut faire un typedef pour clarifier les choses 1 // on définit un nouveau type Pays 2 typedef struct pays Pays; 3 //accès à une valeur 4 Pays monpays = {"Italie", ,300000}; 5 6 void naissance(pays * unpays){ 7 pays->nbhabitants++; 8 } 9 // on peut aussi faire un tableau de structures 0 pays Monde[194]; 1 //... et utiliser l arithmétique des pointeurs 2 pays * p = Monde[0]; 3 for(i=0 ; i <194 ; i++) { 4 printf(p->nom); 5 p++; 6 }

33 Les unions Une union est une variable qui peut prendre des valeurs de types différents Bien sûr pas en même temps! La syntaxe ressemble à celle des structures 1 // on définit l union Nombre et un alias de type 2 typedef union { 3 int vali; 4 float valf; 5 } Nombre ; 6 7 nombre ajouter(nombre a, Nombre b, char type) { 8 nombre result; 9 if (type == i ) { 0 result.vali = a.vali + b.vali ; 1 return result ; 2 } else if ( type == f ) { 3 result.valf = a.valf + b + valf; 4 return result; 5 } else { 6 printf("erreur!\n"); 7 return 0 8 } 9 }

34 Un exemple On veut gérer une base de données de personnes Une première approche : 1 typedef struct Personne { //... 2 } Personne ; 3 Personne mabase[10000]; 4 int taille = 0; 5 //... 6 void add(personne[] base, Personne * unepersonne,int * taille) { 7 if (*taille < 10000) { 8 base[*taille] = *unepersonne; 9 *taille++; 0 } 1 } Ce n est pas très pratique... On consomme beaucoup de pour rien

35 Malloc entre en jeu : l allocation dynamique On demande autant de qu on en a besoin avec On n oublie pas de la libérer quand on a plus besoin avec free 1 #include <stdlib.h> 2 typedef struct Personne { //... 3 Personne * next ; // on va créer une liste chaînée 4 } Personne ; 5 Personne** maliste = NULL ; 6 7 int add(personne** liste, Personne unepersonne); 8 Personne *p = (Personne *) (sizeof(personne)); 9 // on demande de la pour une personne 0 if (p == NULL) { // Il faut toujours faire ça 1 printf("ooops!"); 2 exit(0) ; 3 } else { 4 p->next = *liste ; 5 *liste = p ; 6 }

36 Les Les fonctions ne sont pas des variables, mais on peut quand même créer des pointeurs de fonction. Attention à la priorité entre * et () ; 1 void tri1(int* uneliste) { 2 //... 3 } 4 5 void tri2(int* uneliste) { 6 //... 7 } 8 9 void triliste(int* uneliste, void ( *fonction () ) ) { 0 (*fonction)(uneliste) 1 } 2 //... dans le main 3 if( typetri == 1){ 4 triliste(maliste, &tri1) 5 } else { 6 triliste(maliste, &tri2) 7 }

37 Au programme :

38 La portée La portée (scope) d une variable est l endroit du code où elles sont définies. Par défaut, sont locales à leur bloc. 1 int f(int a,int b) { 2 int c = a * b; 3 // la portée de c va jusqu à la fin de la fonction 4 } 5 6 int main (int argc, char** argv) { 7 double c ; // ce n est pas le même c! 8 int i ; 9 for (i = 0 ; i<=99 ; i++) { 0 char t; 1 // dans ce bloc on peut utiliser c, i et t 2 } 3 // ici, t est hors de portée. 4 } Les variables sont dites automatiques, elles sont détruites quand elles sont hors de portée Attention aux variables en dynamique!

39 Les variables globales On peut déclarer une variable à l extérieur de tout bloc, elle sera visible de tous. 1 int nbappel = 0; 2 int fonction1(int a) { 3 nbappel++; 4 //... 5 } 6 int fonction2(int a) { 7 nbappel++; 8 //... 9 } 0 int main(int argc, char ** argv) { 1 int i; 2 for (i = 0 ; i<1000 ; < i++) { 3 fonction1(i); 4 fonction2(i); 5 if (nbappel > 666) { 6 break; 7 } 8 } 9 }

40 Constantes On peut déclarer une variable constante à l aide du mot clef const. Cela permet d éviter certaines erreurs (mais on peut s en passer) 1 const int a=3; 2 //... 3 a = 42 ; // ERREUR à la compilation Une fonction peut déclarer attendre des arguments constants. Dans ce cas, on est sûr que la fonction ne modifie pas l objet 1 void fonction1(const char* chaine1, char* chaine2) { 2 // cette fonction ne modifie pas chaine1 3 } Bien sûr celà n est utile que lorsqu on passe des pointeurs!

41 Pointeurs et constantes Attention à la syntaxe! 1 const char * p; 2 // p est un pointeur sur un (const char) 3 char c ; p = &c ; // OK 4 *p = a ; // ERREUR : *p ne peut être modifié 1 char * const p ; 2 // p est un pointeur constant sur un char 3 char c ; p = &c ; // ERREUR : p ne peut être modifié 4 *p = a ; // OK 1 const char * const p ; 2 // p est un pointeur constant sur un const char 3 char c ; p = &c ; // ERREUR 4 *p = a ; // ERREUR

42 Les directives de préprocesseur Le préprocesseur agit avant le compilateur Ses commandes commencent par un # Nous en avons rencontré une : #include #include Inclut un fichier en entier #define Effectue un remplacement #if/#endif Compilation conditionelle #pragma Directive spécifique au compilateur (c est mal)

43 #define et les macros Exemple de constante : 1 #define PI Exemple de macro : 1 #define ABS(a) (a>0? a : -a ) Attention aux parenthèses! 1 #define CARRE(a) a*a 2 //... 3 CARRE(a+1); 4 // equivaut à a+1*a+1 = 2a + 1!

44 #if : compilation conditionelle 1 #include stdio.h 2 int main(int argc, char ** argv) { 3 #if WIN32 4 printf("hello, Windows World\n"); 5 #else 6 printf("hello, World\n"); 7 } 8 #endif

45 #include et les headers On regroupe souvent les déclarations de fonctions dans un fichier séparé appelé header 1 // fichier main.h 2 #ifndef MAIN_H // ceci permet de n inclure qu une seule fois le fichier 3 typedef struct Cercle { 4 double rayon; 5 int centre[2]; 6 } Cercle; 7 double aire(cercle *); 8 #define PI 3, #endif 1 // fichier main.c 2 #include "main.h" 3 int main(int argc, char** argv) { 4 Cercle C; 5 double a = aire(&c); 6 } 7 8 double aire(cercle * uncercle) { 9 return PI * (uncercle->rayon) * (uncercle->rayon) ; 0 }

46 , plusieurs fichiers Quand un programme devient trop grand, on le sépare en plusieurs fichiers. Un fichier contient la fonction main, et d autres des fonctions annexes Du coup, on groupe les déclarations dans un ou plusieurs headers L édition des liens permet de créer un programme fonctionnel

47 Un schéma pour mieux comprendre

48 Les bibliothèques On utilise souvent des bibliothèques. Elles sont statiques (liées à la compilation) ou dynamiques (liées juste avant l exécution) Exemple : la lib standard (dont fait partie printf)

49 Un autre schéma

50 Les variables statiques Le mot clef static a plusieurs emplois. Une variable statique survit à la fin de son bloc Un fichier agit comme un bloc pour la portée (pas d accès en dehors du fichier) Les variables statiques sont initialisées à 0 par défaut Exemple : Variable globale statique : 1 static int a = 3; 2 static const char ch = c ; 3 int main (int argc, char** argv) { 4 // on peut utiliser a et ch partout dans le fichier 5 // mais pas ailleurs 6 } Exemple : Variable de fonction statique 1 int mafonction(int param1, double param2) { 2 static int nbappels; 3 // faire des trucs 4 nbappels++; 5 printf("j ai été appelée %d fois \n",nbappels); 6 }

51 Les variables externes extern sert pour globales On utilise extern quand la variable est définie dans un autre fichier Dans la pratique on utilise surtout un header pour les variables globales

52 La bibliothèque stantard J ai la flemme de faire cette slide stdio.h, string.f, stdlib.h, limits.h,...

53 Les trucs dont je n ai pas parlé Les branchements avec switch Les énumérations Les mots-clef volatile et register Plein d autres trucs que j oublie

54 C est fini... ou pas À vous de jouer! Lire le K&R Visiter le site du zéro Lire du code Coder en C!

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

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

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 Anne.Canteaut@inria.fr http://www-rocq.inria.fr/codes/anne.canteaut/cours C 2 Table des matières 3 Table des

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

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 florence.henry@obspm.fr Le Langage C Version 1.2 c 2002 Florence HENRY Observatoire de Paris Université de Versailles florence.henry@obspm.fr Table des matières 1 Les bases 3 2 Variables et constantes 5 3 Quelques fonctions indispensables

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

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

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

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

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 : Pierre-Alain.Fouque@ens.fr Web : http://www.di.ens.fr/~fouque/ Table des matières

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 prenom.nom@mi.parisdescartes.fr 2 Programmation Impérative

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 Christophe.Rippert@Grenoble-INP.fr Introduction Conventions d écriture et outils de mise au point On va utiliser dans cette

Plus en détail

Cours de C. Petits secrets du C & programmation avancée. Sébastien Paumier

Cours de C. Petits secrets du C & programmation avancée. Sébastien Paumier Cours de C Petits secrets du C & programmation avancée Sébastien Paumier paumier@univ-mlv.fr Illustrations provenant du site http://tux.crystalxp.net/ 1 Affectations étendues a+=expression a=a+expression

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

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

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 cegielski@u-pec.fr Introduction à la programmation orientée objet, illustrée par le langage C++ Patrick Cégielski cegielski@u-pec.fr Mars 2002 Pour Irène et Marie Legal Notice Copyright c 2002 Patrick Cégielski Université

Plus en détail

Java Licence Professionnelle CISII, 2009-10

Java Licence Professionnelle CISII, 2009-10 Java Licence Professionnelle CISII, 2009-10 Cours 4 : Programmation structurée (c) http://www.loria.fr/~tabbone/cours.html 1 Principe - Les méthodes sont structurées en blocs par les structures de la programmation

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

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. 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 Enrica.Duchi@liafa.jussieu.fr LANGAGES DE PROGRAMMATION Pour exécuter un algorithme sur un ordinateur il faut le

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

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

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

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

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 cordeau@onera.fr 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

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

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

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

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

as Architecture des Systèmes d Information

as Architecture des Systèmes d Information Plan Plan Programmation - Introduction - Nicolas Malandain March 14, 2005 Introduction à Java 1 Introduction Présentation Caractéristiques Le langage Java 2 Types et Variables Types simples Types complexes

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

Cours de C++ François Laroussinie. 2 novembre 2005. Dept. d Informatique, ENS de Cachan

Cours de C++ François Laroussinie. 2 novembre 2005. Dept. d Informatique, ENS de Cachan Cours de C++ François Laroussinie Dept. d Informatique, ENS de Cachan 2 novembre 2005 Première partie I Introduction Introduction Introduction Algorithme et programmation Algorithme: méthode pour résoudre

Plus en détail

Programmer en JAVA. par Tama (tama@via.ecp.fr( tama@via.ecp.fr)

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

Plus en détail

Arguments d un programme

Arguments d un programme Arguments d un programme L2 SPI, Bruno Jacob 1 Arguments Quand on appelle un programme dans un environnement UNIX ou MS- DOS, on compose une ligne de commandes de la forme : nom-du-programme argument1

Plus en détail

Programmation C. Apprendre à développer des programmes simples dans le langage C

Programmation C. Apprendre à développer des programmes simples dans le langage C Programmation C Apprendre à développer des programmes simples dans le langage C Notes de cours sont disponibles sur http://astro.u-strasbg.fr/scyon/stusm (attention les majuscules sont importantes) Modalités

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

Cours de C. Allocation dynamique. Sébastien Paumier

Cours de C. Allocation dynamique. Sébastien Paumier Cours de C Allocation dynamique Sébastien Paumier paumier@univ-mlv.fr Illustrations provenant du site http://tux.crystalxp.net/ 1 Les pointeurs pointeur=adresse mémoire+type type* nom; nom pointe sur une

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

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

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. Patrick.Corde@idris.fr. 22 juin 2015. Patrick Corde ( Patrick.Corde@idris.fr ) 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 Table des matières I 1 Présentation du langage C Historique Intérêts

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

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

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

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

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 ibr_guelzim@yahoo.fr ibrahimguelzim.atspace.co.uk

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

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

Algorithmique, Structures de données et langage C

Algorithmique, Structures de données et langage C UNIVERSITE PAUL SABATIER TOULOUSE III Algorithmique, Structures de données et langage C L3 IUP AISEM/ICM Janvier 2005 J.M. ENJALBERT Chapitre 1 Rappels et compléments de C 1.1 Structures Une structure

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

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

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

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

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

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

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

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

Éléments d informatique Cours 3 La programmation structurée en langage C L instruction de contrôle if

Éléments d informatique Cours 3 La programmation structurée en langage C L instruction de contrôle if Éléments d informatique Cours 3 La programmation structurée en langage C L instruction de contrôle if Pierre Boudes 28 septembre 2011 This work is licensed under the Creative Commons Attribution-NonCommercial-ShareAlike

Plus en détail

Introduction à la programmation Travaux pratiques: séance d introduction INFO0201-1

Introduction à la programmation Travaux pratiques: séance d introduction INFO0201-1 Introduction à la programmation Travaux pratiques: séance d introduction INFO0201-1 B. Baert & F. Ludewig Bruno.Baert@ulg.ac.be - F.Ludewig@ulg.ac.be Qu est-ce que la programmation? Programmer Ecrire un

Plus en détail

Support de Cours de Langage C. Christian Bac

Support de Cours de Langage C. Christian Bac Support de Cours de Langage C Christian Bac 15 février 2013 ii Table des matières Avant-propos xi 1 Historique et présentation 1 1.1 Historique........................................... 1 1.2 Présentation

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

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

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

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

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 girardot@emse.fr, roelens@emse.fr Septembre 2013 École Nationale

Plus en détail

Introduction à Java. Matthieu Herrb CNRS-LAAS. Mars 2014. http://homepages.laas.fr/matthieu/cours/java/java.pdf

Introduction à Java. Matthieu Herrb CNRS-LAAS. Mars 2014. http://homepages.laas.fr/matthieu/cours/java/java.pdf Introduction à Java Matthieu Herrb CNRS-LAAS http://homepages.laas.fr/matthieu/cours/java/java.pdf Mars 2014 Plan 1 Concepts 2 Éléments du langage 3 Classes et objets 4 Packages 2/28 Histoire et motivations

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

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

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

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

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

Plus en détail

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

Outils pour la pratique

Outils pour la pratique Cinquième partie Outils pour la pratique 121 CHAPITRE 1 Les bases des séances de TP Avant de lire cettre section, il est suggéré de relire vos notes de cours se rapportant au système d exploitation Unix.

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

OS Réseaux et Programmation Système - C5

OS Réseaux et Programmation Système - C5 OS Réseaux et Programmation Système - C5 Rabie Ben Atitallah rabie.benatitallah@univ-valenciennes.fr RPC - XDR Rappel RPC: Remote Procedure Call Besoin d un environnement de haut niveau pour le développement

Plus en détail

MINIMUM. connaissances nécessaires à la programmation des microcontrôleurs PIC18 en langage C (une introduction au langage c A.N.S.

MINIMUM. connaissances nécessaires à la programmation des microcontrôleurs PIC18 en langage C (une introduction au langage c A.N.S. MINIMUM connaissances nécessaires à la programmation des microcontrôleurs PIC18 en langage C (une introduction au langage c A.N.S.I maj n 4) Equipe de formation sur les microcontrôleurs PIC Robert Toquebeuf

Plus en détail

Introduction à l algorithmique et à la programmation M1102 CM n 3

Introduction à l algorithmique et à la programmation M1102 CM n 3 Introduction à l algorithmique et à la programmation M1102 CM n 3 DUT Informatique 1 re année Eric REMY eric.remy@univ-amu.fr IUT d Aix-Marseille, site d Arles Version du 2 octobre 2013 E. Remy (IUT d

Plus en détail

Suivant les langages de programmation, modules plus avancés : modules imbriqués modules paramétrés par des modules (foncteurs)

Suivant les langages de programmation, modules plus avancés : modules imbriqués modules paramétrés par des modules (foncteurs) Modularité Extensions Suivant les langages de programmation, modules plus avancés : modules imbriqués modules paramétrés par des modules (foncteurs) généricité modules de première classe : peuvent être

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

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

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

Archivage Messagerie Evolution pour usage HTML en utilisant Hypermail

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

Plus en détail

Notions fondamentales du langage C# Version 1.0

Notions fondamentales du langage C# Version 1.0 Notions fondamentales du langage C# Version 1.0 Z 2 [Notions fondamentales du langage Csharp] [Date : 25/03/09] Sommaire 1 Tout ce qu il faut savoir pour bien commencer... 3 1.1 Qu est ce qu un langage

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

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 de Programmation Impérative: Zones de mémoires et pointeurs

Cours de Programmation Impérative: Zones de mémoires et pointeurs Cours de Programmation Impérative: Zones de mémoires et pointeurs Julien David A101 - david@lipn.univ-paris13.fr Julien David (A101 - david@lipn.univ-paris13.fr) 1 / 1 Z`o n`e s `d`e m`é m`o i r`e Julien

Plus en détail

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

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 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 ben_mamoun@fsr.ac.ma 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 2011/2012 Pr. Ben Mamoun 1 Plan du cours (1) 1. Introduction 2. Types, opérateurs

Plus en détail

Solutions du chapitre 4

Solutions du chapitre 4 Solutions du chapitre 4 Structures de contrôle: première partie 4.9 Identifiez et corrigez les erreurs (il peut y en avoir plus d une par segment de code) de chacune des proposition suivantes: a) if (

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

INF 104 (SELC) 2012-2013 Introduction au langage C

INF 104 (SELC) 2012-2013 Introduction au langage C INF 104 (SELC) 2012-2013 Introduction au langage C Plan Première partie C après Java Structure d un programme Préprocesseur Variables Types de base Types composés Pointeurs(1) Instructions Deuxième partie

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

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 de C/C++ par la pratique. Hugues Talbot

Cours de C/C++ par la pratique. Hugues Talbot Cours de C/C++ par la pratique Hugues Talbot 24 octobre 2008 2 Table des matières 1 Comment démarrer? 7 1.1 Un programme simple en C pur.......................... 7 1.2 Un programme en C ++...............................

Plus en détail

Analyse de sécurité de logiciels système par typage statique

Analyse de sécurité de logiciels système par typage statique Contexte Modélisation Expérimentation Conclusion Analyse de sécurité de logiciels système par typage statique Application au noyau Linux Étienne Millon UPMC/LIP6 Airbus Group Innovations Sous la direction

Plus en détail

Introduction à la Programmation Parallèle: MPI

Introduction à la Programmation Parallèle: MPI Introduction à la Programmation Parallèle: MPI Frédéric Gava et Gaétan Hains L.A.C.L Laboratoire d Algorithmique, Complexité et Logique Cours du M2 SSI option PSSR Plan 1 Modèle de programmation 2 3 4

Plus en détail

Premiers Pas en Programmation Objet : les Classes et les Objets

Premiers Pas en Programmation Objet : les Classes et les Objets Chapitre 2 Premiers Pas en Programmation Objet : les Classes et les Objets Dans la première partie de ce cours, nous avons appris à manipuler des objets de type simple : entiers, doubles, caractères, booléens.

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

Langage et Concepts de ProgrammationOrientée-Objet 1 / 40

Langage et Concepts de ProgrammationOrientée-Objet 1 / 40 Déroulement du cours Introduction Concepts Java Remarques Langage et Concepts de Programmation Orientée-Objet Gauthier Picard École Nationale Supérieure des Mines de Saint-Étienne gauthier.picard@emse.fr

Plus en détail