<?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 => 'uk',
  ),
  'this' => 
  array (
    0 => 'language.operators.increment.php',
    1 => 'Increment and Decrement',
    2 => 'Incrementing/Decrementing Operators',
  ),
  'up' => 
  array (
    0 => 'language.operators.php',
    1 => 'Operators',
  ),
  'prev' => 
  array (
    0 => 'language.operators.arithmetic.php',
    1 => 'Arithmetic',
  ),
  'next' => 
  array (
    0 => 'language.operators.assignment.php',
    1 => 'Assignment',
  ),
  'alternatives' => 
  array (
  ),
  'source' => 
  array (
    'lang' => 'en',
    '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">Incrementing/Decrementing Operators</h2>
 
 <p class="para">
  PHP supports pre- and post-increment and decrement operators.
  Those unary operators allow to increment or decrement the value by one.
 </p>
 <table class="doctable table">
  <caption><strong>Increment/decrement Operators</strong></caption>
  
   <thead>
    <tr>
     <th>Example</th>
     <th>Name</th>
     <th>Effect</th>
    </tr>

   </thead>

   <tbody class="tbody">
    <tr>
     <td>++$a</td>
     <td>Pre-increment</td>
     <td>Increments <var class="varname">$a</var> by one, then returns <var class="varname">$a</var>.</td>
    </tr>

    <tr>
     <td>$a++</td>
     <td>Post-increment</td>
     <td>Returns <var class="varname">$a</var>, then increments <var class="varname">$a</var> by one.</td>
    </tr>

    <tr>
     <td>--$a</td>
     <td>Pre-decrement</td>
     <td>Decrements <var class="varname">$a</var> by one, then returns <var class="varname">$a</var>.</td>
    </tr>

    <tr>
     <td>$a--</td>
     <td>Post-decrement</td>
     <td>Returns <var class="varname">$a</var>, then decrements <var class="varname">$a</var> by one.</td>
    </tr>

   </tbody>
  
 </table>


 <p class="para">
  <div class="example" id="example-1">
   <p><strong>Приклад #1 Examples of Increment/Decrement</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-increment:'</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">'Pre-increment:'</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">'Post-decrement:'</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">'Pre-decrement:'</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>Поданий вище приклад
виведе:</p></div>
   <div class="example-contents screen">
<div class="annotation-interactive cdata"><pre>
Post-increment:
int(5)
int(6)
Pre-increment:
int(6)
int(6)
Post-decrement:
int(5)
int(4)
Pre-decrement:
int(4)
int(4)
</pre></div>
   </div>
  </div>

  <div class="warning"><strong class="warning">Увага</strong>
   <p class="para">
    The increment and decrement operators have no effect on values
    of type <span class="type"><a href="language.types.boolean.php" class="type bool">bool</a></span>.
    A <strong><code><a href="errorfunc.constants.php#constant.e-warning">E_WARNING</a></code></strong> is emitted as of PHP 8.3.0,
    because this will implicitly cast the value to <span class="type"><a href="language.types.integer.php" class="type int">int</a></span> in the future.
   </p>
   <p class="para">
    The decrement operator has no effect on values
    of type <span class="type"><a href="language.types.null.php" class="type null">null</a></span>.
    A <strong><code><a href="errorfunc.constants.php#constant.e-warning">E_WARNING</a></code></strong> is emitted as of PHP 8.3.0,
    because this will implicitly cast the value to <span class="type"><a href="language.types.integer.php" class="type int">int</a></span> in the future.
   </p>
   <p class="para">
    The decrement operator has no effect on non-
    <a href="language.types.numeric-strings.php" class="link">numeric string</a>.
    A <strong><code><a href="errorfunc.constants.php#constant.e-warning">E_WARNING</a></code></strong> is emitted as of PHP 8.3.0,
    because a <span class="classname"><a href="class.typeerror.php" class="classname">TypeError</a></span> will be thrown in the future.
   </p>
  </div>
  <blockquote class="note"><p><strong class="note">Зауваження</strong>: 
   <p class="para">
    Internal objects that support overloading addition and/or subtraction
    can also be incremented and/or decremented.
    One such internal object is <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">PERL string increment feature</h3>
  <div class="warning"><strong class="warning">Увага</strong>
   <p class="simpara">
    This feature is soft-deprecated as of PHP 8.3.0.
    The <span class="function"><a href="function.str-increment.php" class="function">str_increment()</a></span> function should be used instead.
   </p>
  </div>

  <p class="para">
   It is possible to increment a non-
   <a href="language.types.numeric-strings.php" class="link">numeric string</a>
   in PHP. The string must be an alphanumerical ASCII string.
   Which increments letters up to the next letter, when reaching the letter
   <code class="literal">Z</code> the increment is carried to the value on the left.
   For example, <code class="code">$a = &#039;Z&#039;; $a++;</code> turns <var class="varname">$a</var>
   into <code class="literal">&#039;AA&#039;</code>.
  </p>

  <div class="example" id="example-2">
   <p><strong>Приклад #2 PERL string increment example</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">'== Alphabetic strings ==' </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">// Alphanumeric strings behave differently<br /></span><span style="color: #007700">echo </span><span style="color: #DD0000">'== Alphanumeric strings ==' </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>Поданий вище приклад
виведе:</p></div>
   <div class="example-contents screen">
<div class="annotation-interactive cdata"><pre>
== Alphabetic strings ==
X
Y
Z
AA
AB
AC
== Alphanumeric strings ==
A9
B0
B1
B2
B3
B4
A09
A10
A11
A12
A13
A14
</pre></div>
   </div>
  </div>

  <div class="warning"><strong class="warning">Увага</strong>
   <p class="para">
    If the alphanumerical string can be interpreted as a
    <a href="language.types.numeric-strings.php" class="link">numeric string</a>
    it will be cast to an <span class="type"><a href="language.types.integer.php" class="type int">int</a></span> or <span class="type"><a href="language.types.float.php" class="type float">float</a></span>.
    This is particularly an issue with strings that look like a floating point
    numbers written in exponential notation.
    The <span class="function"><a href="function.str-increment.php" class="function">str_increment()</a></span> function does not suffer from
    these implicit type cast.
   </p>
   <div class="example" id="example-3">
    <p><strong>Приклад #3 Alphanumerical string converted to 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>Поданий вище приклад
виведе:</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>
     This is because the value <code class="literal">&quot;5e0&quot;</code> is interpreted
     as a <span class="type"><a href="language.types.float.php" class="type float">float</a></span> and cast to the value <code class="literal">5.0</code>
     before being incremented.
    </p></div>
   </div>
  </div>
 </div>
</div><?php manual_footer($setup); ?>