Initialisation des types scalaires
Lorsque vous initialisez des types scalaires, la valeur de assignment-expression
est attribuée à la variable. Les règles de conversion pour l'assignation s'appliquent. (Consultez Conversions de type pour plus d'informations sur les règles de conversion.)
declaration
:
declaration-specifiers
init-declarator-list
opt ;
declaration-specifiers
:
storage-class-specifier
declaration-specifiers
opt
type-specifier
declaration-specifiers
opt
type-qualifier
declaration-specifiers
opt
init-declarator-list
:
init-declarator
init-declarator-list
,
init-declarator
init-declarator
:
declarator
declarator
=
initializer
/* Pour l’initialisation scalaire */
initializer
:
assignment-expression
Vous pouvez initialiser des variables de tout type, à condition de respecter les règles suivantes :
Les variables déclarées au niveau de la portée du fichier peuvent être initialisées. Si vous n'initialisez pas explicitement une variable au niveau externe, elle est initialisée à 0 par défaut.
Une expression constante peut être utilisée pour initialiser une variable globale déclarée avec le
static
storage-class-specifier
. Les variables déclarées comme étantstatic
sont initialisées lorsque l'exécution du programme démarre. Si vous n'initialisez pas explicitement une variable globalestatic
, elle est initialisée à 0 par défaut, et un pointeur null est assigné à chaque membre de type pointeur.Des variables déclarées avec le spécificateur de classe de stockage
auto
ouregister
sont initialisées chaque fois que le contrôle d'exécution passe au bloc dans lequel elles sont déclarées. Si vous omettez un initialiseur à partir de la déclaration d'une variableauto
ouregister
, la valeur initiale de la variable est indéfinie. Pour les valeurs auto et register, l'initialiseur n'est pas simplement une constante. Il peut s'agir d'une expression utilisant des valeurs définies précédemment, même des appels de fonction.Les valeurs initiales pour les déclarations de variables externes et pour toutes les variables
static
, qu'elles soient externes ou internes, doivent être des expressions constantes. (Pour plus d’informations, consultez expressions constantes.) Étant donné que l'adresse de toute variable statique ou déclarée extérieurement est constante, elle peut être utilisée pour initialiser une variable pointeurstatic
déclarée en interne. Toutefois, l'adresse d'une variableauto
ne peut pas être utilisée comme initialiseur statique, car elle peut être différente pour chaque exécution du bloc. Vous pouvez utiliser des valeurs constantes ou variables pour initialiser les variablesauto
etregister
.Si la déclaration d’un identificateur a une portée de bloc, et si l’identificateur a une liaison externe, la déclaration ne peut pas avoir d’initialisation.
Les exemples suivants illustrent les initialisations :
int x = 10;
La variable de type entier x
est initialisée à l'expression constante 10
.
register int *px = 0;
Le pointeur px
est initialisé à 0, produisant un pointeur Null.
const int c = (3 * 1024);
Cet exemple utilise une expression constante (3 * 1024)
pour initialiser c
à une valeur de constante qui ne peut pas être modifiée en raison du mot clé const
.
int *b = &x;
Cette instruction initialise le pointeur b
avec l'adresse d'une autre variable, x
.
int *const a = &z;
Le pointeur a
est initialisé avec l'adresse d'une variable nommée z
. Toutefois, étant donné qu'elle est spécifiée comme étant const
, la variable a
peut seulement être initialisée, jamais modifiée. Elle pointe toujours vers le même emplacement.
int GLOBAL ;
int function( void )
{
int LOCAL ;
static int *lp = &LOCAL; /* Illegal initialization */
static int *gp = &GLOBAL; /* Legal initialization */
register int *rp = &LOCAL; /* Legal initialization */
}
La variable globale GLOBAL
est déclarée au niveau externe. Elle a donc une durée de vie globale. La variable locale LOCAL
a une classe de stockage auto
et a une adresse seulement pendant l'exécution de la fonction dans laquelle elle est déclarée. Par conséquent, il n'est pas autorisé de tenter d'initialiser la variable pointeur static
lp
avec l'adresse de LOCAL
. La variable pointeur static
gp
peut être initialisée à l'adresse de GLOBAL
, car cette adresse ne varie pas. De même, *rp
peut être initialisé car rp
est une variable locale pouvant avoir un initialiseur non constant. Chaque fois que le bloc est écrit, LOCAL
a une nouvelle adresse, qui est ensuite assignée à rp
.