<?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 => 'pt_BR',
  ),
  'this' => 
  array (
    0 => 'language.operators.increment.php',
    1 => 'Incremento e Decremento',
    2 => 'Operadores de Incremento/Decremento',
  ),
  'up' => 
  array (
    0 => 'language.operators.php',
    1 => 'Operadores',
  ),
  'prev' => 
  array (
    0 => 'language.operators.arithmetic.php',
    1 => 'Aritm&eacute;ticos',
  ),
  'next' => 
  array (
    0 => 'language.operators.assignment.php',
    1 => 'Atribui&ccedil;&atilde;o',
  ),
  'alternatives' => 
  array (
  ),
  'source' => 
  array (
    'lang' => 'pt_BR',
    '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">Operadores de Incremento/Decremento</h2>
 
 <p class="para">
  O PHP suporta operadores de pré e pós-incremento operadores de decremento.
  Esses operadores unários permitem aumentar o diminuir o valor por um.
 </p>
 <table class="doctable table">
  <caption><strong>Operadores de Incremento/Decremento</strong></caption>
  
   <thead>
    <tr>
     <th>Exemplo</th>
     <th>Nome</th>
     <th>Efeito</th>
    </tr>

   </thead>

   <tbody class="tbody">
    <tr>
     <td>++$a</td>
     <td>Pré-incremento</td>
     <td>Incrementa <var class="varname">$a</var> em um, e então retorna <var class="varname">$a</var>.</td>
    </tr>

    <tr>
     <td>$a++</td>
     <td>Pós-incremento</td>
     <td>Retorna <var class="varname">$a</var>, e então incrementa <var class="varname">$a</var> em um.</td>
    </tr>

    <tr>
     <td>--$a</td>
     <td>Pré-decremento</td>
     <td>Diminuiu <var class="varname">$a</var> em um, e então retorna <var class="varname">$a</var>.</td>
    </tr>

    <tr>
     <td>$a--</td>
     <td>Pós-decremento</td>
     <td>Retorna <var class="varname">$a</var>, e então diminui <var class="varname">$a</var> em um.</td>
    </tr>

   </tbody>
  
 </table>


 <p class="para">
  <div class="example" id="example-1">
   <p><strong>Exemplo #1 Exemplos de incremento/decremento</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">'Pós-incremento:'</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 /><br />echo </span><span style="color: #DD0000">'Pré-incremento:'</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 /><br />echo </span><span style="color: #DD0000">'Pós-incremento:'</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 /><br />echo </span><span style="color: #DD0000">'Pré-decremento:'</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>O exemplo acima produzirá:</p></div>
   <div class="example-contents screen">
<div class="annotation-interactive cdata"><pre>
Pós-incremento:
int(5)
int(6)
Pré-incremento:
int(6)
int(6)
Pós-incremento:
int(5)
int(4)
Pós-decremento:
int(4)
int(4)
</pre></div>
   </div>
  </div>

  <div class="warning"><strong class="warning">Aviso</strong>
   <p class="para">
    Os operadores de incremento e decremento não tem efeitos em valores
    do tipo <span class="type"><a href="language.types.boolean.php" class="type bool">bool</a></span>.
    Um <strong><code><a href="errorfunc.constants.php#constant.e-warning">E_WARNING</a></code></strong> é emitido desde o PHP 8.3.0,
    porque isso causará uma conversão implícita para um tipo <span class="type"><a href="language.types.integer.php" class="type int">int</a></span> no futuro.
   </p>
   <p class="para">
    O operador de decremento não tem efeito em valores
    do tipo <span class="type"><a href="language.types.null.php" class="type null">null</a></span>.
    Um <strong><code><a href="errorfunc.constants.php#constant.e-warning">E_WARNING</a></code></strong> é emitido desde o PHP 8.3.0,
    porque isso causará uma conversão implícita para um tipo <span class="type"><a href="language.types.integer.php" class="type int">int</a></span> no futuro.
   </p>
   <p class="para">
    O operador de decremento não tem efeito em strings não
    <a href="language.types.numeric-strings.php" class="link">numéricas</a>.
    Um <strong><code><a href="errorfunc.constants.php#constant.e-warning">E_WARNING</a></code></strong> é emitido desde o PHP 8.3.0,
    porque isso lançará um <span class="classname"><a href="class.typeerror.php" class="classname">TypeError</a></span> no futuro.
   </p>
  </div>
  <blockquote class="note"><p><strong class="note">Nota</strong>: 
   <p class="para">
    Objetos internos que suportam a sobrecarga de adição ou subtração
    também podem ser incrementados ou decrementados.
    Um exemplo de objeto assim é o <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">Incremento de strings no estilo PERL</h3>
  <div class="warning"><strong class="warning">Aviso</strong>
   <p class="simpara">
    Esse recurso está desencorajado desde o PHP 8.3.0.
    A função <span class="function"><a href="function.str-increment.php" class="function">str_increment()</a></span> deve ser utilizada.
   </p>
  </div>

  <p class="para">
   É possível incremente strings não
   <a href="language.types.numeric-strings.php" class="link">numéricas</a>
   no PHP. A string precisa ser um texto ASCII.
   O efeito é incrementar a última letra até a próxima, e quando é alcançada a letra
   <code class="literal">Z</code> o incremento é carregado para a letra à esquerda.
   Por exemplo, <code class="code">$a = &#039;Z&#039;; $a++;</code> transforma <var class="varname">$a</var>
   em <code class="literal">&#039;AA&#039;</code>.
  </p>

  <div class="example" id="example-2">
   <p><strong>Exemplo #2 Exemplo de incremento de string estilo 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">'== String alfabética ==' </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">// String alfanuméricas tem outro comportamento<br /></span><span style="color: #007700">echo </span><span style="color: #DD0000">'== Strings alfanuméricas ==' </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>O exemplo acima produzirá:</p></div>
   <div class="example-contents screen">
<div class="annotation-interactive cdata"><pre>
== String alfabética ==
X
Y
Z
AA
AB
AC
== Strings alfanuméricas ==
A9
B0
B1
B2
B3
B4
A09
A10
A11
A12
A13
A14
</pre></div>
   </div>
  </div>

  <div class="warning"><strong class="warning">Aviso</strong>
   <p class="para">
    Se uma string alfanumérica pode ser interpretada como uma
    <a href="language.types.numeric-strings.php" class="link">string numérica</a>
    ela será convertida para um <span class="type"><a href="language.types.integer.php" class="type int">int</a></span> ou <span class="type"><a href="language.types.float.php" class="type float">float</a></span>.
    Isso pode ser um problema para strings que parecem como números de ponto flutuante
    escritos em notação exponencial.
    A função <span class="function"><a href="function.str-increment.php" class="function">str_increment()</a></span> não sofre desse problema
    de conversão implícita.
   </p>
   <div class="example" id="example-3">
    <p><strong>Exemplo #3 Strings alfanuméricas convertida para float</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>O exemplo acima produzirá:</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>
     Isto ocorre porque o valor <code class="literal">&quot;5e0&quot;</code> é interpretado
     como <span class="type"><a href="language.types.float.php" class="type float">float</a></span> e é convertido para o valor de <code class="literal">5.0</code>
     antes de ser incrementado.
    </p></div>
   </div>
  </div>
 </div>
</div><?php manual_footer($setup); ?>