IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Visual C++ Discussion :

Ordre de compilation des fichiers


Sujet :

Visual C++

  1. #1
    Candidat au Club
    Profil pro
    Inscrit en
    Août 2007
    Messages
    2
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2007
    Messages : 2
    Points : 3
    Points
    3
    Par défaut Ordre de compilation des fichiers
    Bonjour,

    Je travaille sur un projet qui comporte plusieurs fichiers.
    Lorsque je compile le projet, la compilation commence par le dernier fichier ajouté au projet ce qui me cré des erreurs.
    Comment faire pour forcer la compilation en premier sur le fichier principal du projet afin que les fichiers soient traités dans l'ordre de leur inclusion par la commande #include?
    Par ailleurs que pensez vous de placer les variables globales dans un fichier séparé?
    Y a til des différences de traitements entre les fichiers .cpp et .h, car pour ces derniers, on peut utiliser les directives #if defined, peut on aussi les utliser pour des fichiers .cpp qui contiennent des classes et leur fonctions?

  2. #2
    Expert éminent sénior
    Avatar de koala01
    Homme Profil pro
    aucun
    Inscrit en
    Octobre 2004
    Messages
    11 614
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 52
    Localisation : Belgique

    Informations professionnelles :
    Activité : aucun

    Informations forums :
    Inscription : Octobre 2004
    Messages : 11 614
    Points : 30 626
    Points
    30 626
    Par défaut
    Salut,

    Il faut être très attentif à ce qu'on met dans quel fichier:

    Un fichier *.h est un fichier d'en-tête: il sert à contenir
    • les définitions de classe (le fait de dire à quoi elles ressemblent: type et nom des membres, prototype des fonction membre),
    • la déclaration des fonctions libres (le fait de fournir le prototype des fonctions: leur "signature", sans fournir la logique à suivre)
    • la déclaration des variables globales (le fait de dire que telle variable existe et qu'elle est de tel type)

    Les fichier *.cpp sont des fichiers d'implémentation: ils contiennent
    • l'initialisation des variables globales
    • la définition des fonctions libres (le fait de fournir la suite logique des instructions que doit effectuer la fonction)
    • la définition des fonctions membres

    On ne le répétera jamais assez, les variable globales, c'est mal... je tiens les explication là dessus "au chaud" si tu veux savoir pourquoi

    Il n'y a que les fichiers d'en-tête qui doivent (puissent ) être inclus dans d'autre fichiers: le compilateur travaille comme le lecteur d'un livre: de haut en bas... Quand on est à la page 8 d'un livre, on sait tout ce qui s'est passé dans les 7 premières pages, mais on ignore tout de ce qui se passe en page 10 (du moins, si c'est la première fois qu'on lit le livre )

    Pour qu'il sache provoquer l'appel d'une fonction, il faut juste qu'il connaisse le prototype de cette fonction (le type de valeur qu'elle renvoie, son nom et les paramètres qu'elle accepte), autrement dit: il doit disposer du fichier d'en-tête dans lequel la fonction (ou la fonction membre) est déclarée...

    Il est à noter que si tu inclus le fichier A.h dans un fichier d'implémentation, et que A.h inclus le fichier B.h qui, lui-même inclus le fichier C.h (qui lui-même inclus...) le fichier d'implémentation saura que, non seulement, tout ce qui est déclaré dans A.h existe, mais aussi tout ce qui est déclaré dans B.h, dans C.h etc.: on peut réellement parler d'inclusion en cascade sur ce coup là

    Si tu respecte les règles, l'ordre de compilation ne pose aucun problème: tous les fichiers sont compilés séparément, puis c'est le rôle de l'éditeur de liens que de faire pointer les appels de fonctions aux bons endroits

    La suite, vers 23h00, si tu a d'autres questions (j'ai un train à prendre, là )
    A méditer: La solution la plus simple est toujours la moins compliquée
    Ce qui se conçoit bien s'énonce clairement, et les mots pour le dire vous viennent aisément. Nicolas Boileau
    Compiler Gcc sous windows avec MinGW
    Coder efficacement en C++ : dans les bacs le 17 février 2014
    mon tout nouveau blog

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. [Tableaux] ordre de lecture des fichiers
    Par 123quatre dans le forum Langage
    Réponses: 3
    Dernier message: 25/09/2007, 16h30
  2. Peut-on compiler des fichiers BAT ou CMD svp ?
    Par arnofly dans le forum Scripts/Batch
    Réponses: 7
    Dernier message: 18/05/2007, 17h56
  3. Ordre de compilation des modules
    Par poulacou dans le forum Fortran
    Réponses: 1
    Dernier message: 28/02/2007, 15h15
  4. Réponses: 6
    Dernier message: 12/09/2006, 18h25
  5. Les logiciels pour compiler des fichiers HTML en fichiers d’
    Par Edoxituz dans le forum Balisage (X)HTML et validation W3C
    Réponses: 6
    Dernier message: 23/02/2006, 17h02

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo