INFO517 : Programmation C
Cours du semestre 5 de la licence STIC INFO.
Responsable pour 2008--2009: Lionel Vaux.
Pensez à consulter les indications pour compiler un petit programme sur une machine des salles de TP.
N'hésitez pas à contribuer au wiki, et en particulier à cette page: clarifications, compléments, exemples… Si vous n'avez pas compris un point particulier, vous pouvez signaler votre problème sur la page de discussion (onglet en haut de cette page) ou par les moyens habituels. Il sera ensuite très positif de revenir sur cette page et de consigner ce qui vous posait problème et ce qui vous a permis de mieux comprendre.
Fonctionnement
Cet enseignement comprendra 10 séances de cours/TD (1h30) et 3 séances de TP (4h).
La distinction entre cours et TD restera floue. Je vous demanderai généralement d'écrire quelques petits programmes d'une semaine sur l'autre. Autant que possible, envoyez-moi vos fichiers sources à l'adresse lionel.vaux@univ-savoie.fr, afin que je puisse évaluer le niveau de chacun et ajuster le contenu des séances suivantes.
Et dites-moi si ça ne va pas, ou je risque d'avancer trop vite.
Objectifs du cours
Cours/TD
- Principes généraux et particularités du langage: programmation impérative, typage fort à la compilation, adressage mémoire explicite
- Syntaxe de base
- Bibliothèque standard: entrée-sorties et interaction avec le système d'exploitation
- C avancé:
- allocation dynamique
- modèle mémoire (pile, tas, code)
- pointeurs sur structures
- pointeurs sur fonctions
- Bonnes pratiques
En TP
- un TP de mise en route et de précision de la notion de compilation en C
- un projet logiciel sur les deux dernières séances (8h)
Outils et concepts (survol théorique et utilisation optionnelle en TP)
- automatisation de la compilation (make),
- analyse de l'exécution et déboguage (gdb et DDD),
- boîte à outils graphique (gtk+)
Supports
- Exercices de TD :
- la feuille 1 ;
- la feuille 2 et une archive liste.tar.gz comprenant une solution pour l'implémentation des listes et des listes triées (les piles ont été traitées en séance 7).
- Devoir à la maison : le sujet INFO517-DM1.pdf et les fichiers sources dm1.c et mat.c associés.
- Partiels :
- sujet INFO517-Partiel1.pdf et corrigé INFO517-Partiel1-correction.pdf.
- sujet INFO517-Partiel2.pdf et corrigé INFO517-Partiel2-correction.pdf.
Séances de Cours/TD
- lundi 22 septembre 2008.
- mise en route: exemples de programmes simples et compilation;
- syntaxe de base: types, déclarations, affectations, boucles, entrées et sorties simples (caractère par caractère);
- lundi 29 septembre 2008
- fonctions;
- tableaux et chaînes;
- récursion;
- lundi 6 octobre 2008
- exercices (feuille 1);
- lundi 13 octobre 2008
- adresses et pointeurs;
- passage par adresse;
- les tableaux comme pointeurs;
- opérateur sizeof;
- arithmétique de pointeurs;
- allocation des variables locales: le problème des tableaux;
- allocation dynamique: malloc(), free(), realloc();
- lundi 20 octobre 2008
- modèle mémoire: pile, tas, segment de code;
- différence entre déclaration de tableau et déclaration de pointeur;
- affichage des données de la pile d'exécution, adresses de retour;
- lundi 3 novembre 2008
- types complexes: struct, union, enum;
- premier partiel;
- lundi 10 novembre 2008
- pointeurs vers struct;
- structures récursives;
- exemple: les piles (FILO);
- Makefiles;
- exercices (feuille 2);
- lundi 17 novembre 2008
- correction du premier partiel;
- exercices (suite de la feuille 2);
- lundi 24 novembre 2008
- préparation du TP1
- entrées et sorties dans des fichiers
- opérations bit-à-bit;
- lundi 1er décembre 2008
- deuxième partiel;
- pointeurs sur fonctions;
- une session DDD;
Séances de TP
Les sujets de TP se trouvent sur cette page.
- mercredi 15 octobre 2008 : TP0 — Préliminaires
- vendredi 28 novembre 2008 : TP1 — Formats d'image
- vendredi 12 décembre 2008 : TP2 — Affichage et interface graphique
Références
- The C programming language, de Kernighan et Ritchie;
- Le langage C, version française du précédent;
- Le polycopié de Bernard Cassagne, disponible ici, au format html (consultable en ligne) ou pdf;
- Le wikilivre Programmation C: un livre de cours sur le mode wikipedia.