<?php
include_once $_SERVER['DOCUMENT_ROOT'] . '/include/shared-manual.inc';
$TOC = array();
$TOC_DEPRECATED = array();
$PARENTS = array();
include_once dirname(__FILE__) ."/toc/language.operators.inc";
$setup = array (
  'home' => 
  array (
    0 => 'index.php',
    1 => 'PHP Manual',
  ),
  'head' => 
  array (
    0 => 'UTF-8',
    1 => 'fr',
  ),
  'this' => 
  array (
    0 => 'language.operators.increment.php',
    1 => 'Incr&eacute;mentation et d&eacute;cr&eacute;mentation',
    2 => 'Op&eacute;rateurs d\'incr&eacute;mentation et d&eacute;cr&eacute;mentation',
  ),
  'up' => 
  array (
    0 => 'language.operators.php',
    1 => 'Les op&eacute;rateurs',
  ),
  'prev' => 
  array (
    0 => 'language.operators.arithmetic.php',
    1 => 'Arithm&eacute;tique',
  ),
  'next' => 
  array (
    0 => 'language.operators.assignment.php',
    1 => 'Affectation',
  ),
  'alternatives' => 
  array (
  ),
  'source' => 
  array (
    'lang' => 'fr',
    'path' => 'language/operators/increment.xml',
  ),
  'history' => 
  array (
  ),
);
$setup["toc"] = $TOC;
$setup["toc_deprecated"] = $TOC_DEPRECATED;
$setup["parents"] = $PARENTS;
manual_setup($setup);

contributors($setup);

?>
<div id="language.operators.increment" class="sect1">
 <h2 class="title">Opérateurs d&#039;incrémentation et décrémentation</h2>
 
 <p class="para">
  PHP prend en charge les opérateurs de pré- et post-incrémentation et décrémentation.
  Ces opérateurs unaires permettent d&#039;augmenter ou de diminuer la valeur d&#039;une unité.
 </p>
 <table class="doctable table">
  <caption><strong>Opérateurs d&#039;incrémentation et décrémentation</strong></caption>
  
   <thead>
    <tr>
     <th>Exemple</th>
     <th>Nom</th>
     <th>Résultat</th>
    </tr>

   </thead>

   <tbody class="tbody">
    <tr>
     <td>++$a</td>
     <td>Pré-incrémente</td>
     <td>
      Incrémente <var class="varname">$a</var> de 1, puis retourne
      <var class="varname">$a</var>.
     </td>
    </tr>

    <tr>
     <td>$a++</td>
     <td>Post-incrémente</td>
     <td>Retourne <var class="varname">$a</var>, puis incrémente <var class="varname">$a</var> de 1.</td>
    </tr>

    <tr>
     <td>--$a</td>
     <td>Pré-décrémente</td>
     <td>
      Décrémente <var class="varname">$a</var> de 1, puis retourne
      <var class="varname">$a</var>.
     </td>
    </tr>

    <tr>
     <td>$a--</td>
     <td>Post-décrémente</td>
     <td>
      Retourne <var class="varname">$a</var>, puis décrémente
      <var class="varname">$a</var> de 1.
     </td>
    </tr>

   </tbody>
  
 </table>


 <p class="para">
  <div class="example" id="example-1">
   <p><strong>Exemple #1 Exemples d&#039;incrémentation/décrémentation</strong></p>
   <div class="example-contents">
<div class="annotation-interactive phpcode"><code><span style="color: #000000"><span style="color: #0000BB">&lt;?php<br /></span><span style="color: #007700">echo </span><span style="color: #DD0000">'Post-incrément:'</span><span style="color: #007700">, </span><span style="color: #0000BB">PHP_EOL</span><span style="color: #007700">;<br /></span><span style="color: #0000BB">$a </span><span style="color: #007700">= </span><span style="color: #0000BB">5</span><span style="color: #007700">;<br /></span><span style="color: #0000BB">var_dump</span><span style="color: #007700">(</span><span style="color: #0000BB">$a</span><span style="color: #007700">++);<br /></span><span style="color: #0000BB">var_dump</span><span style="color: #007700">(</span><span style="color: #0000BB">$a</span><span style="color: #007700">);<br />echo </span><span style="color: #DD0000">'Pré-incrément:'</span><span style="color: #007700">, </span><span style="color: #0000BB">PHP_EOL</span><span style="color: #007700">;<br /></span><span style="color: #0000BB">$a </span><span style="color: #007700">= </span><span style="color: #0000BB">5</span><span style="color: #007700">;<br /></span><span style="color: #0000BB">var_dump</span><span style="color: #007700">(++</span><span style="color: #0000BB">$a</span><span style="color: #007700">);<br /></span><span style="color: #0000BB">var_dump</span><span style="color: #007700">(</span><span style="color: #0000BB">$a</span><span style="color: #007700">);<br />echo </span><span style="color: #DD0000">'Post-décrément:'</span><span style="color: #007700">, </span><span style="color: #0000BB">PHP_EOL</span><span style="color: #007700">;<br /></span><span style="color: #0000BB">$a </span><span style="color: #007700">= </span><span style="color: #0000BB">5</span><span style="color: #007700">;<br /></span><span style="color: #0000BB">var_dump</span><span style="color: #007700">(</span><span style="color: #0000BB">$a</span><span style="color: #007700">--);<br /></span><span style="color: #0000BB">var_dump</span><span style="color: #007700">(</span><span style="color: #0000BB">$a</span><span style="color: #007700">);<br />echo </span><span style="color: #DD0000">'Pré-décrément:'</span><span style="color: #007700">, </span><span style="color: #0000BB">PHP_EOL</span><span style="color: #007700">;<br /></span><span style="color: #0000BB">$a </span><span style="color: #007700">= </span><span style="color: #0000BB">5</span><span style="color: #007700">;<br /></span><span style="color: #0000BB">var_dump</span><span style="color: #007700">(--</span><span style="color: #0000BB">$a</span><span style="color: #007700">);<br /></span><span style="color: #0000BB">var_dump</span><span style="color: #007700">(</span><span style="color: #0000BB">$a</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="annotation-interactive cdata"><pre>
Post-incrément:
int(5)
int(6)
Pré-incrément:
int(6)
int(6)
Post-décrément:
int(5)
int(4)
Pré-décrément:
int(4)
int(4)
</pre></div>
   </div>
  </div>
  <div class="warning"><strong class="warning">Avertissement</strong>
   <p class="para">
    Les opérateurs d&#039;incrémentation et de décrémentation n&#039;ont aucun effet sur les valeurs
    de type <span class="type"><a href="language.types.boolean.php" class="type bool">bool</a></span>.
    Un <strong><code><a href="errorfunc.constants.php#constant.e-warning">E_WARNING</a></code></strong> est émis à partir de PHP 8.3.0,
    car cela convertira implicitement la valeur en <span class="type"><a href="language.types.integer.php" class="type int">int</a></span> à l&#039;avenir.
   </p>
   <p class="para">
    L&#039;opérateur de décrémentation n&#039;a aucun effet sur les valeurs
    de type <span class="type"><a href="language.types.null.php" class="type null">null</a></span>.
    Un <strong><code><a href="errorfunc.constants.php#constant.e-warning">E_WARNING</a></code></strong> est émis à partir de PHP 8.3.0,
    car cela convertira implicitement la valeur en <span class="type"><a href="language.types.integer.php" class="type int">int</a></span> à l&#039;avenir.
   </p>
   <p class="para">
    L&#039;opérateur de décrémentation n&#039;a aucun effet sur les
    <a href="language.types.numeric-strings.php" class="link">chaînes non numériques</a>.
    Un <strong><code><a href="errorfunc.constants.php#constant.e-warning">E_WARNING</a></code></strong> est émis à partir de PHP 8.3.0,
    car une <span class="classname"><a href="class.typeerror.php" class="classname">TypeError</a></span> sera levée à l&#039;avenir.
   </p>
  </div>
  <blockquote class="note"><p><strong class="note">Note</strong>: 
   <p class="para">
    Les objets internes qui prennent en charge la surcharge de l&#039;addition et/ou de la soustraction
    peuvent également être incrémentés et/ou décrémentés.
    Un tel objet interne est <span class="classname"><a href="class.gmp.php" class="classname">GMP</a></span>.
   </p>
  </p></blockquote>
 </p>

 <div class="sect2" id="language.operators.increment.string">
  <h3 class="title">Fonctionnalité d&#039;incrémentation de chaînes PERL</h3>
  <div class="warning"><strong class="warning">Avertissement</strong>
   <p class="simpara">
    Cette fonctionnalité est obsolète de manière souple à partir de PHP 8.3.0.
    La fonction <span class="function"><a href="function.str-increment.php" class="function">str_increment()</a></span> devrait être utilisée à la place.
   </p>
  </div>

  <p class="para">
   Il est possible d&#039;incrémenter une
   <a href="language.types.numeric-strings.php" class="link">chaîne non numérique</a>
   dans PHP. La chaîne doit être une chaîne ASCII alphanumérique.
   Cela incrémente les lettres jusqu&#039;à la lettre suivante, et lorsque la lettre
   <code class="literal">Z</code> est atteinte, l&#039;incrément est reporté à la valeur à gauche.
   Par exemple, <code class="code">$a = &#039;Z&#039;; $a++;</code> transforme <var class="varname">$a</var>
   en <code class="literal">&#039;AA&#039;</code>.
  </p>

  <div class="example" id="example-2">
   <p><strong>Exemple #2 Exemple d&#039;incrémentation de chaîne PERL</strong></p>
   <div class="example-contents">
<div class="annotation-interactive phpcode"><code><span style="color: #000000"><span style="color: #0000BB">&lt;?php<br /></span><span style="color: #007700">echo </span><span style="color: #DD0000">'== Chaînes alphabétiques ==' </span><span style="color: #007700">. </span><span style="color: #0000BB">PHP_EOL</span><span style="color: #007700">;<br /></span><span style="color: #0000BB">$s </span><span style="color: #007700">= </span><span style="color: #DD0000">'W'</span><span style="color: #007700">;<br />for (</span><span style="color: #0000BB">$n</span><span style="color: #007700">=</span><span style="color: #0000BB">0</span><span style="color: #007700">; </span><span style="color: #0000BB">$n</span><span style="color: #007700">&lt;</span><span style="color: #0000BB">6</span><span style="color: #007700">; </span><span style="color: #0000BB">$n</span><span style="color: #007700">++) {<br />    echo ++</span><span style="color: #0000BB">$s </span><span style="color: #007700">. </span><span style="color: #0000BB">PHP_EOL</span><span style="color: #007700">;<br />}<br /></span><span style="color: #FF8000">// Les chaînes alphanumériques se comportent différemment<br /></span><span style="color: #007700">echo </span><span style="color: #DD0000">'== Chaînes alphanumériques ==' </span><span style="color: #007700">. </span><span style="color: #0000BB">PHP_EOL</span><span style="color: #007700">;<br /></span><span style="color: #0000BB">$d </span><span style="color: #007700">= </span><span style="color: #DD0000">'A8'</span><span style="color: #007700">;<br />for (</span><span style="color: #0000BB">$n</span><span style="color: #007700">=</span><span style="color: #0000BB">0</span><span style="color: #007700">; </span><span style="color: #0000BB">$n</span><span style="color: #007700">&lt;</span><span style="color: #0000BB">6</span><span style="color: #007700">; </span><span style="color: #0000BB">$n</span><span style="color: #007700">++) {<br />    echo ++</span><span style="color: #0000BB">$d </span><span style="color: #007700">. </span><span style="color: #0000BB">PHP_EOL</span><span style="color: #007700">;<br />}<br /></span><span style="color: #0000BB">$d </span><span style="color: #007700">= </span><span style="color: #DD0000">'A08'</span><span style="color: #007700">;<br />for (</span><span style="color: #0000BB">$n</span><span style="color: #007700">=</span><span style="color: #0000BB">0</span><span style="color: #007700">; </span><span style="color: #0000BB">$n</span><span style="color: #007700">&lt;</span><span style="color: #0000BB">6</span><span style="color: #007700">; </span><span style="color: #0000BB">$n</span><span style="color: #007700">++) {<br />    echo ++</span><span style="color: #0000BB">$d </span><span style="color: #007700">. </span><span style="color: #0000BB">PHP_EOL</span><span style="color: #007700">;<br />}<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="annotation-interactive cdata"><pre>
== Chaînes alphabétiques ==
X
Y
Z
AA
AB
AC
== Chaînes alphanumériques ==
A9
B0
B1
B2
B3
B4
A09
A10
A11
A12
A13
A14
</pre></div>
   </div>
  </div>
  <div class="warning"><strong class="warning">Avertissement</strong>
   <p class="para">
    Si la chaîne alphanumérique peut être interprétée comme une
    <a href="language.types.numeric-strings.php" class="link">chaîne numérique</a>,
    elle sera convertie en <span class="type"><a href="language.types.integer.php" class="type int">int</a></span> ou en <span class="type"><a href="language.types.float.php" class="type float">float</a></span>.
    C&#039;est particulièrement problématique avec les chaînes qui ressemblent à des nombres à virgule flottante
    écrits en notation exponentielle.
    La fonction <span class="function"><a href="function.str-increment.php" class="function">str_increment()</a></span> ne souffre pas de
    ces conversions de type implicites.
   </p>
   <div class="example" id="example-3">
    <p><strong>Exemple #3 Conversion de chaîne alphanumérique en flottant</strong></p>
    <div class="example-contents">
<div class="annotation-interactive phpcode"><code><span style="color: #000000"><span style="color: #0000BB">&lt;?php<br />$s </span><span style="color: #007700">= </span><span style="color: #DD0000">"5d9"</span><span style="color: #007700">;<br /></span><span style="color: #0000BB">var_dump</span><span style="color: #007700">(++</span><span style="color: #0000BB">$s</span><span style="color: #007700">);<br /></span><span style="color: #0000BB">var_dump</span><span style="color: #007700">(++</span><span style="color: #0000BB">$s</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="annotation-interactive cdata"><pre>
string(3) &quot;5e0&quot;
float(6)
</pre></div>
    </div>
    <div class="example-contents"><p>
     Cela est dû au fait que la valeur <code class="literal">&quot;5e0&quot;</code> est interprétée
     comme un <span class="type"><a href="language.types.float.php" class="type float">float</a></span> et convertie en la valeur <code class="literal">5.0</code>
     avant d&#039;être incrémentée.
    </p></div>
   </div>
  </div>
 </div>
</div><?php manual_footer($setup); ?>