<?php
include_once $_SERVER['DOCUMENT_ROOT'] . '/include/shared-manual.inc';
$TOC = array();
$TOC_DEPRECATED = array();
$PARENTS = array();
include_once dirname(__FILE__) ."/toc/language.variables.inc";
$setup = array (
  'home' => 
  array (
    0 => 'index.php',
    1 => 'PHP Manual',
  ),
  'head' => 
  array (
    0 => 'UTF-8',
    1 => 'fr',
  ),
  'this' => 
  array (
    0 => 'language.variables.basics.php',
    1 => 'Essentiel',
    2 => 'Essentiel',
  ),
  'up' => 
  array (
    0 => 'language.variables.php',
    1 => 'Les variables',
  ),
  'prev' => 
  array (
    0 => 'language.variables.php',
    1 => 'Les variables',
  ),
  'next' => 
  array (
    0 => 'language.variables.predefined.php',
    1 => 'Variables pr&eacute;d&eacute;finies',
  ),
  'alternatives' => 
  array (
  ),
  'source' => 
  array (
    'lang' => 'fr',
    'path' => 'language/variables.xml',
  ),
  'history' => 
  array (
  ),
);
$setup["toc"] = $TOC;
$setup["toc_deprecated"] = $TOC_DEPRECATED;
$setup["parents"] = $PARENTS;
manual_setup($setup);

contributors($setup);

?>
<div id="language.variables.basics" class="sect1">
  <h2 class="title">Essentiel</h2>
  
  <p class="simpara">
   En PHP, les variables sont représentées par un signe
   dollar &quot;$&quot; suivi du nom de la variable. Le nom est sensible à
   la casse.
  </p>
  
  <p class="para">
   Un nom de variable valide commence par une lettre
   (<code class="literal">A-Z</code>, <code class="literal">a-z</code>, ou les octets de 128 à 255)
   ou par un souligné (_), suivi de lettres, chiffres ou
   soulignés. Exprimé sous la forme d&#039;une expression
   régulière, cela donne :
   <code class="code">^[a-zA-Z_\x80-\xff][a-zA-Z0-9_\x80-\xff]*$</code>
  </p>
  
  <blockquote class="note"><p><strong class="note">Note</strong>: 
   <span class="simpara">
    PHP ne prend pas en charge les noms de variables Unicode, cependant, certains
    encodages de caractères (comme UTF-8) encodent les caractères de manière
    que tous les octets d&#039;un caractère multi-octet soient dans la plage
    autorisée, ce qui en fait ainsi un nom de variable valide.
   </span>
  </p></blockquote>
  
  <blockquote class="note"><p><strong class="note">Note</strong>: 
   <span class="simpara">
    <code class="literal">$this</code> est une variable spéciale,
    qui ne peut pas être assignée.
    Avant PHP 7.1.0, l&#039;affectation indirecte (c.-à-d. en utilisant
     <a href="language.variables.variable.php" class="link">les variables variables</a>)
     était impossible.
   </span>
  </p></blockquote>
  
  <div class="tip"><strong class="tip">Astuce</strong><p class="simpara">
 Jetez un oeil sur <a href="userlandnaming.php" class="xref">Guide de nommage de l'espace utilisateur</a>.
</p></div>
  
  <div class="example" id="example-1">
    <p><strong>Exemple #1 Noms de variables valides</strong></p>
    <div class="example-contents">
<div class="phpcode"><code><span style="color: #000000"><span style="color: #0000BB">&lt;?php<br />$var </span><span style="color: #007700">= </span><span style="color: #DD0000">'Jean'</span><span style="color: #007700">;<br /></span><span style="color: #0000BB">$Var </span><span style="color: #007700">= </span><span style="color: #DD0000">'Paul'</span><span style="color: #007700">;<br />echo </span><span style="color: #DD0000">"</span><span style="color: #0000BB">$var</span><span style="color: #DD0000">, </span><span style="color: #0000BB">$Var</span><span style="color: #DD0000">"</span><span style="color: #007700">;         </span><span style="color: #FF8000">// affiche "Jean, Paul"<br /><br /></span><span style="color: #0000BB">$_4site </span><span style="color: #007700">= </span><span style="color: #DD0000">'pas encore'</span><span style="color: #007700">;    </span><span style="color: #FF8000">// valide : commence par un souligné<br /></span><span style="color: #0000BB">$täyte </span><span style="color: #007700">= </span><span style="color: #DD0000">'mansikka'</span><span style="color: #007700">;    </span><span style="color: #FF8000">// valide : 'ä' est ASCII (étendu) 228.<br /></span><span style="color: #0000BB">?&gt;</span></span></code></div>
  </div>

   </div>
   <div class="example" id="example-2">
    <p><strong>Exemple #2 Noms de variables invalides</strong></p>
    <div class="example-contents">
<div class="phpcode"><code><span style="color: #000000"><span style="color: #0000BB">&lt;?php<br /></span><span style="color: #007700">$</span><span style="color: #0000BB">4site </span><span style="color: #007700">= </span><span style="color: #DD0000">'pas encore'</span><span style="color: #007700">;     </span><span style="color: #FF8000">// invalide : commence par un nombre</span></span></code></div>
    </div>

   </div>


   <p class="simpara">
    PHP accepte une séquence de n&#039;importe quels octets comme nom de variable. 
    Les noms de variables qui ne respectent pas les règles de nommage mentionnées ci-dessus 
    ne peuvent être accédés que dynamiquement à l&#039;exécution. Voir 
    <a href="language.variables.variable.php" class="link">variables variables</a> 
    pour plus d&#039;informations sur la façon d&#039;y accéder.
   </p>

   <div class="example" id="example-3">
    <p><strong>Exemple #3 Accéder à des noms de variables inhabituels</strong></p>
    <div class="example-contents">
<div class="phpcode"><code><span style="color: #000000"><span style="color: #0000BB">&lt;?php<br /></span><span style="color: #007700">${</span><span style="color: #DD0000">'nom-invalide'</span><span style="color: #007700">} = </span><span style="color: #DD0000">'bar'</span><span style="color: #007700">;<br /></span><span style="color: #0000BB">$nom </span><span style="color: #007700">= </span><span style="color: #DD0000">'nom-invalide'</span><span style="color: #007700">;<br />echo ${</span><span style="color: #DD0000">'nom-invalide'</span><span style="color: #007700">}, </span><span style="color: #DD0000">" "</span><span style="color: #007700">, $</span><span style="color: #0000BB">$nom</span><span style="color: #007700">;<br /></span><span style="color: #0000BB">?&gt;</span></span></code></div>
    </div>

    <div class="example-contents"><p>L&#039;exemple ci-dessus va afficher :</p></div>
    <div class="example-contents screen">
<div class="cdata"><pre>
bar bar
</pre></div>
    </div>
   </div>

  <p class="para">
   Par défaut, les variables sont toujours assignées par valeur.
   C&#039;est-à-dire, lorsqu&#039;une expression est affectée à une variable,
   la valeur de l&#039;expression est recopiée dans
   la variable. Cela signifie, par exemple, qu&#039;après avoir
   assigné la valeur d&#039;une variable à une autre,
   modifier l&#039;une des variables n&#039;aura pas d&#039;effet sur l&#039;autre. Pour plus
   de détails sur ce genre d&#039;assignation, se reporter aux
   <a href="language.expressions.php" class="link">expressions</a>.
  </p>
  <p class="para">
   PHP permet aussi d&#039;assigner les valeurs aux variables
   <a href="language.references.php" class="link">par référence</a>. Cela
   signifie que la nouvelle variable ne fait que référencer
   (en d&#039;autres termes, &quot;devient un alias de&quot;, ou encore &quot;pointe sur&quot;) la
   variable originale. Les modifications de la nouvelle variable
   affecteront l&#039;ancienne et vice versa.
  </p>
  <p class="para">
   Pour assigner par référence, il suffit d&#039;ajouter
   un &amp; (ET commercial) au début de la variable qui
   est assignée (la variable source). Dans l&#039;exemple suivant,
   <code class="literal">Mon nom est Pierre</code> s&#039;affichera deux
   fois :
   <div class="informalexample">
    <div class="example-contents">
<div class="phpcode"><code><span style="color: #000000"><span style="color: #0000BB">&lt;?php<br />$foo </span><span style="color: #007700">= </span><span style="color: #DD0000">'Pierre'</span><span style="color: #007700">;              </span><span style="color: #FF8000">// Assigne la valeur 'Pierre' à $foo<br /></span><span style="color: #0000BB">$bar </span><span style="color: #007700">= &amp;</span><span style="color: #0000BB">$foo</span><span style="color: #007700">;                 </span><span style="color: #FF8000">// Référence $foo avec $bar.<br /></span><span style="color: #0000BB">$bar </span><span style="color: #007700">= </span><span style="color: #DD0000">"Mon nom est </span><span style="color: #0000BB">$bar</span><span style="color: #DD0000">"</span><span style="color: #007700">;  </span><span style="color: #FF8000">// Modifie $bar...<br /></span><span style="color: #007700">echo </span><span style="color: #0000BB">$bar</span><span style="color: #007700">;<br />echo </span><span style="color: #0000BB">$foo</span><span style="color: #007700">;                    </span><span style="color: #FF8000">// $foo est aussi modifiée<br /></span><span style="color: #0000BB">?&gt;</span></span></code></div>
    </div>

   </div>
  </p>
  
  <p class="para">
   Une chose importante à noter est que seules les variables
   peuvent être assignées par référence.
   <div class="informalexample">
    <div class="example-contents">
<div class="phpcode"><code><span style="color: #000000"><span style="color: #0000BB">&lt;?php<br />$foo </span><span style="color: #007700">= </span><span style="color: #0000BB">25</span><span style="color: #007700">;<br /></span><span style="color: #0000BB">$bar </span><span style="color: #007700">= &amp;</span><span style="color: #0000BB">$foo</span><span style="color: #007700">;      </span><span style="color: #FF8000">// assignation valide<br /></span><span style="color: #0000BB">$bar </span><span style="color: #007700">= &amp;(</span><span style="color: #0000BB">24 </span><span style="color: #007700">* </span><span style="color: #0000BB">7</span><span style="color: #007700">);  </span><span style="color: #FF8000">// assignation invalide : référence une expression sans nom<br /><br /></span><span style="color: #007700">function </span><span style="color: #0000BB">test</span><span style="color: #007700">()<br />{<br />   return </span><span style="color: #0000BB">25</span><span style="color: #007700">;<br />}<br /><br /></span><span style="color: #0000BB">$bar </span><span style="color: #007700">= &amp;</span><span style="color: #0000BB">test</span><span style="color: #007700">();    </span><span style="color: #FF8000">// invalide car test() ne retourne pas une variable par référence.<br /></span><span style="color: #0000BB">?&gt;</span></span></code></div>
    </div>

   </div>
  </p>

  <p class="para">
   Il n&#039;est pas nécessaire de déclarer des variables en PHP, cependant, c&#039;est une très
   bonne pratique. Accéder à une variable non définie entraînera un
   <strong><code><a href="errorfunc.constants.php#constant.e-warning">E_WARNING</a></code></strong> (avant PHP 8.0.0, <strong><code><a href="errorfunc.constants.php#constant.e-notice">E_NOTICE</a></code></strong>).
   Une variable non définie a une valeur par défaut de <strong><code><a href="reserved.constants.php#constant.null">null</a></code></strong>.
   La construction de langage <span class="function"><a href="function.isset.php" class="function">isset()</a></span> peut être utilisée
   pour détecter si une variable a déjà été initialisée.
  </p>
  <p class="para">
   <div class="example" id="example-4">
    <p><strong>Exemple #4 Valeur par défaut d&#039;une variable non initialisée</strong></p>
    <div class="example-contents">
<div class="phpcode"><code><span style="color: #000000"><span style="color: #0000BB">&lt;?php<br /></span><span style="color: #FF8000">// Une variable non initialisée et non référencée (pas de contexte d'utilisation).<br /></span><span style="color: #0000BB">var_dump</span><span style="color: #007700">(</span><span style="color: #0000BB">$unset_var</span><span style="color: #007700">);<br /></span><span style="color: #0000BB">?&gt;</span></span></code></div>
    </div>

    <div class="example-contents"><p>L&#039;exemple ci-dessus va afficher :</p></div>
     <div class="example-contents screen">
<div class="cdata"><pre>
Warning: Undefined variable $unset_var in ...
NULL
</pre></div>
     </div>
   </div>
  </p>
   <p class="simpara">
    PHP permet l&#039;autovivification de tableaux (création automatique de nouveaux tableaux)
    à partir d&#039;une variable non définie.
    Ajouter un élément à une variable non définie créera un nouveau tableau et
    ne générera pas d&#039;avertissement.
   </p>
   <div class="example" id="example-5">
    <p><strong>Exemple #5 Autovivification d&#039;un tableau à partir d&#039;une variable non définie</strong></p>
    <div class="example-contents">
<div class="phpcode"><code><span style="color: #000000"><span style="color: #0000BB">&lt;?php<br />$unset_array</span><span style="color: #007700">[] = </span><span style="color: #DD0000">'valeur'</span><span style="color: #007700">; </span><span style="color: #FF8000">// Ne génère pas d'avertissement.<br /></span><span style="color: #0000BB">?&gt;</span></span></code></div>
    </div>

   </div>

   <div class="warning"><strong class="warning">Avertissement</strong>
    <p class="simpara">
     Compter sur la valeur par défaut d&#039;une variable non initialisée est problématique
     lorsqu&#039;un fichier inclus dans un autre utilise le même
     nom de variable.
    </p>
   </div>

   <p class="simpara">
    Une variable peut être détruite en utilisant la construction de langage <span class="function"><a href="function.unset.php" class="function">unset()</a></span>.
   </p>

   <p class="simpara">
    Pour plus d&#039;informations sur les fonctions liées aux variables, consulter la
    <a href="ref.var.php" class="link">Référence des fonctions sur les variables</a>.
   </p>
 </div><?php manual_footer($setup); ?>