Difference between revisions of "Courses/CMP2"

From LRDE

Line 9: Line 9:
 
|optional course=non
 
|optional course=non
 
|module=Génie Logiciel et Programmation
 
|module=Génie Logiciel et Programmation
|prerequisites=CMP1
+
|prerequisites=[[Courses/CMP1|CMP1]]
 
|objectives=Comprendre la traduction de langages, les optimisations. Mieux comprendre quand on peut avoir confiance dans du code généré/traduit automatiquement par rapport à du code écrit à la main.
 
|objectives=Comprendre la traduction de langages, les optimisations. Mieux comprendre quand on peut avoir confiance dans du code généré/traduit automatiquement par rapport à du code écrit à la main.
   
Line 24: Line 24:
 
* Vivacité des variables
 
* Vivacité des variables
 
* Allocation de registres
 
* Allocation de registres
 
 
|references=http://www.lrde.epita.fr/~tiger/
 
|references=http://www.lrde.epita.fr/~tiger/
 
Modern Compiler Implementation par Andrew Appel
 
Modern Compiler Implementation par Andrew Appel
 
http://tiger.lrde.epita.fr/
 
http://tiger.lrde.epita.fr/
 
|slides=http://www.lrde.epita.fr/~tiger/lecture-notes/
 
|slides=http://www.lrde.epita.fr/~tiger/lecture-notes/
 
 
|logbook=Courses/CompilationLecture2005,
 
|logbook=Courses/CompilationLecture2005,
 
Courses/CompilationLecture2006,
 
Courses/CompilationLecture2006,

Revision as of 10:01, 30 June 2014

Titre

Construction des Compilateurs 2

Sigle

CMP2

Enseignant

Roland Levillain

Période

S2, Ing1

Public

Tronc-commun

Contrôle

Partiel, Projet

Durée

12H"H" is not declared as a valid unit of measurement for this property.

Optionnel

non

Module

Génie Logiciel et Programmation

Prérequis

[[Course prerequisites::CMP1]]

Objectifs

Comprendre la traduction de langages, les optimisations. Mieux comprendre quand on peut avoir confiance dans du code généré/traduit automatiquement par rapport à du code écrit à la main.

Le compilateur est l'interface principale du programmeur vers la machine. On ne peut pas être un bon programmeur sans savoir d'un côté comment fonctionne un ordinateur (cours d'architecture, de système, d'assembleur, etc.) et de l'autre le langage de commande (cours de d'algorithmie, de C, C++, Eiffel, etc.). Sans une bonne connaissance des compilateurs ---le pont entre le programmeur et la machine-- cette connaissance est illusoire et donne lieu à des « mythes urbains de programmeurs ».

Ce cours vise à démystifier la théorie de la compilation en couvrant dans le détail le fonctionnement de l'intégralité d'un compilateur. À l'issue de cet enseignement les étudiants comprennent mieux leurs outils pour devenir de meilleurs ingénieurs du logiciel.

Plan
  • Contrôle des types
  • Langages intermédiaires
  • Passages d'arguments
  • Mémoire : hiérarchie des mémoires matérielles, gestion logicielle de la mémoire
  • Les microprocesseurs : CISC, RISC
  • Sélection d'instructions (génération de code)
  • Flot d'exécution
  • Vivacité des variables
  • Allocation de registres
Documentation
Support
Journaux