#include, directive (C/C++)
Indique au préprocesseur de traiter le contenu d'un fichier spécifique, comme s'il figurait dans le programme source à l'emplacement où figure la directive.
#include "path-spec"
#include <path-spec>
Notes
Vous pouvez organiser les définitions de constantes et de macros dans des fichiers Include, puis utiliser des directives #include pour les ajouter à un fichier source quelconque. Les fichiers Include sont également utiles pour incorporer des déclarations de variables externes et de types de données complexes. Les types peuvent être définis et nommés une seule fois dans un fichier Include créé à cet effet.
path-spec est un nom de fichier pouvant éventuellement être précédé d'une spécification de répertoire. Le nom de fichier doit désigner un fichier existant. La syntaxe du nom path-spec dépend du système d'exploitation sur lequel le programme est compilé.
Pour plus d'informations sur le référencement des assemblys dans une application C++ compilée à l'aide de /clr, reportez-vous à l'article #using.
Les deux formes de syntaxe provoquent le remplacement de cette directive par le contenu complet du fichier Include spécifié. La différence entre ces deux formes concerne l'ordre dans lequel le préprocesseur recherche les fichiers d'en-tête lorsque le chemin d'accès est spécifié de manière incomplète. Le tableau ci-dessous montre la différence entre les deux formes de syntaxe.
Forme syntaxique |
Action |
---|---|
Forme avec guillemets |
Le préprocesseur recherche les fichiers Include dans l'ordre suivant :
|
Forme avec crochets pointus |
Le préprocesseur recherche les fichiers Include dans l'ordre suivant :
|
Le préprocesseur arrête de chercher dès qu'il trouve un fichier portant le nom spécifié. Si vous spécifiez un chemin d'accès complet et non équivoque pour le fichier Include entre guillemets doubles (" "), le préprocesseur recherche uniquement dans le répertoire défini par ce chemin d'accès et ignore les répertoires standard.
Si le nom de fichier placé entre guillemets doubles est un chemin d'accès incomplet, le préprocesseur commence la recherche dans le répertoire du fichier parent. Le fichier parent est le fichier qui contient la directive #include. Par exemple, si vous incluez un fichier nommé file2 dans un fichier nommé file1, file1 est le fichier parent.
Les fichiers Include peuvent être « imbriqués ». En d'autres termes, une directive #include peut figurer dans un fichier nommé par une autre directive #include. Par exemple, file2 peut inclure file3. Dans ce cas, file1 reste le parent de file2 et représente le « grand-parent » de file3.
Lorsque des fichiers Include sont imbriqués et que la compilation s'effectue à partir de la ligne de commande, la recherche dans les répertoires commence dans les répertoires du fichier parent, puis se poursuit dans les répertoires de tous les fichiers grands-parents. Autrement dit, la recherche commence par rapport au répertoire contenant la source actuellement traitée. Si le fichier est introuvable, la recherche se déplace vers les répertoires spécifiés par l'option /I du compilateur. Finalement, la recherche s'effectue dans les répertoires spécifiés par la variable d'environnement INCLUDE.
Dans l'environnement de développement, la variable d'environnement INCLUDE est ignorée. Pour plus d'informations sur la manière de définir les répertoires dans lesquels les fichiers Include sont recherchés (cela s'applique également à la variable d'environnement LIB), reportez-vous à l'article VC++ Directories, Projects, Options Dialog Box.
Cet exemple illustre l'inclusion d'un fichier à l'aide de crochets pointus :
#include <stdio.h>
Cet exemple ajoute le contenu du fichier nommé STDIO.H dans le programme source. Les crochets pointus indiquent au préprocesseur de rechercher STDIO.H dans les répertoires spécifiés par la variable d'environnement INCLUDE, après avoir cherché dans les répertoires spécifiés par l'option /I du compilateur.
L'exemple suivant illustre l'inclusion d'un fichier en utilisant la forme entre guillemets :
#include "defs.h"
Cet exemple ajoute dans le programme source le contenu du fichier spécifié par DEFS.H. Les guillemets indiquent que le préprocesseur doit chercher d'abord dans le répertoire contenant le fichier source parent.
L'imbrication des fichiers Include peut atteindre jusqu'à 10 niveaux. Lorsque l'instruction #include imbriquée est traitée, le préprocesseur continue à insérer le fichier Include englobant dans le fichier source d'origine.
Section spécifique à Microsoft
Pour localiser les fichiers sources à inclure, le préprocesseur commence par chercher dans les répertoires spécifiés par l'option /I du compilateur. Si l'option /I est absente ou échoue, le préprocesseur utilise la variable d'environnement INCLUDE pour rechercher tous les fichiers Include entre crochets pointus. La variable d'environnement INCLUDE et l'option /I du compilateur peuvent contenir plusieurs chemins d'accès, séparés par des points-virgules (;). Si plusieurs répertoires figurent dans l'option /I ou la variable d'environnement INCLUDE, le préprocesseur les traite dans l'ordre dans lequel ils apparaissent.
Par exemple, la commande
CL /ID:\MSVC\INCLUDE MYPROG.C
indique au préprocesseur de rechercher les fichiers Include tels que STDIO.H dans le répertoire D:\MSVC\INCLUDE\. Les commandes
SET INCLUDE=D:\MSVC\INCLUDE
CL MYPROG.C
ont le même effet. Si les deux jeux de recherches échouent, une erreur irrécupérable du compilateur est générée.
Si le nom de fichier est complètement spécifié pour un fichier Include et comporte un chemin d'accès comprenant un signe deux-points (par exemple, F:\MSVC\SPECIAL\INCL\TEST.H), le préprocesseur suit le chemin d'accès.
Pour les fichiers Include spécifiés sous la forme #include "path-spec", la recherche dans les répertoires commence par le répertoire du fichier parent et se poursuit dans les répertoires de tous les fichiers grands-parents. Autrement dit, la recherche commence par rapport au répertoire qui contient le fichier source qui contient la directive #include en cours de traitement. S'il n'existe aucun fichier grand-parent et que le fichier n'a pas été trouvé, la recherche se poursuit comme si le nom de fichier était placé entre crochets pointus.
FIN de la section spécifique à Microsoft