<?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 => 'ru',
  ),
  'this' => 
  array (
    0 => 'language.operators.increment.php',
    1 => 'Инкремент и декремент',
    2 => 'Операторы инкремента и декремента',
  ),
  'up' => 
  array (
    0 => 'language.operators.php',
    1 => 'Операторы',
  ),
  'prev' => 
  array (
    0 => 'language.operators.arithmetic.php',
    1 => 'Арифметика',
  ),
  'next' => 
  array (
    0 => 'language.operators.assignment.php',
    1 => 'Присваивание',
  ),
  'alternatives' => 
  array (
  ),
  'source' => 
  array (
    'lang' => 'ru',
    '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">Операторы инкремента и декремента</h2>
 
 <p class="para">
  PHP поддерживает префиксные и постфиксные операторы инкремента и декремента.
  Эти унарные операторы разрешают увеличивать или уменьшать значение на единицу.
 </p>
 <table class="doctable table">
  <caption><strong>Операторы инкремента и декремента</strong></caption>
  
   <thead>
    <tr>
     <th>Пример</th>
     <th>Название</th>
     <th>Действие</th>
    </tr>

   </thead>

   <tbody class="tbody">
    <tr>
     <td>++$a</td>
     <td>Префиксный инкремент</td>
     <td>Увеличивает <var class="varname">$a</var> на единицу, затем возвращает значение <var class="varname">$a</var>.</td>
    </tr>

    <tr>
     <td>$a++</td>
     <td>Постфиксный инкремент</td>
     <td>Возвращает значение <var class="varname">$a</var>, затем увеличивает <var class="varname">$a</var> на единицу.</td>
    </tr>

    <tr>
     <td>--$a</td>
     <td>Префиксный декремент</td>
     <td>Уменьшает <var class="varname">$a</var> на единицу, затем возвращает значение <var class="varname">$a</var>.</td>
    </tr>

    <tr>
     <td>$a--</td>
     <td>Постфиксный декремент</td>
     <td>Возвращает значение <var class="varname">$a</var>, затем уменьшает <var class="varname">$a</var> на единицу.</td>
    </tr>

   </tbody>
  
 </table>


 <p class="para">
  <div class="example" id="example-1">
   <p><strong>Пример #1 Примеры инкремента и декремента</strong></p>
   <div class="example-contents">
<div class="annotation-interactive phpcode"><code><span style="color: #000000"><span style="color: #0000BB">&lt;?php<br /><br /></span><span style="color: #007700">echo </span><span style="color: #DD0000">'Постфиксный инкремент:'</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">'Префиксный инкремент:'</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">'Постфиксный декремент:'</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">'Префиксный декремент:'</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">);</span></span></code></div>
   </div>

   
<div class="example-contents"><p>
 Результат выполнения приведённого примера:
</p></div>

   <div class="example-contents screen">
<div class="annotation-interactive cdata"><pre>
Постфиксный инкремент:
int(5)
int(6)
Префиксный инкремент:
int(6)
int(6)
Постфиксный декремент:
int(5)
int(4)
Префиксный декремент:
int(4)
int(4)
</pre></div>
   </div>
  </div>

  <div class="warning"><strong class="warning">Внимание</strong>
   <p class="para">
    Операторы инкремента и декремента не влияют на логические значения (<span class="type"><a href="language.types.boolean.php" class="type bool">bool</a></span>).
    Начиная с PHP 8.3.0 вызывается ошибка уровня <strong><code><a href="errorfunc.constants.php#constant.e-warning">E_WARNING</a></code></strong>,
    потому что в будущем это будет неявно приведено к значению целого числа (<span class="type"><a href="language.types.integer.php" class="type int">int</a></span>).
   </p>
   <p class="para">
    Оператор декремента не влияет на значения <span class="type"><a href="language.types.null.php" class="type null">null</a></span>.
    Начиная с PHP 8.3.0 вызывается ошибка уровня <strong><code><a href="errorfunc.constants.php#constant.e-warning">E_WARNING</a></code></strong>,
    потому что в будущем это будет неявно приведено к значению целого числа (<span class="type"><a href="language.types.integer.php" class="type int">int</a></span>).
   </p>
   <p class="para">
    Оператор декремента не влияет на не-
    <a href="language.types.numeric-strings.php" class="link">числовые строки</a>.
    Начиная с PHP 8.3.0 вызывается ошибка уровня <strong><code><a href="errorfunc.constants.php#constant.e-warning">E_WARNING</a></code></strong>,
    потому в будущем будет выбрасываться исключение <span class="classname"><a href="class.typeerror.php" class="classname">TypeError</a></span>.
   </p>
  </div>
  <blockquote class="note"><p><strong class="note">Замечание</strong>: 
   <p class="para">
    Внутренние объекты, которые поддерживают перегрузку сложения и/или вычитания,
    могут также быть инкрементированы и/или декрементированы.
    Один такой внутренний объект — это <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</h3>
  <div class="warning"><strong class="warning">Внимание</strong>
   <p class="simpara">
    Начиная с PHP 8.3.0 эта функция мягко устарела.
    Вместо этого вызывают функцию <span class="function"><a href="function.str-increment.php" class="function">str_increment()</a></span>.
   </p>
  </div>

  <p class="para">
   В PHP можно инкрементировать не-
   <a href="language.types.numeric-strings.php" class="link">числовую строку</a>.
   Строка  должна быть буквенно-цифровой последовательностью в кодировке ASCII.
   Буквы увеличиваются до следующей буквы, при достижении буквы
   <code class="literal">Z</code> инкремент переносится в следующий разряд слева.
   Например, выражение <code class="code">$a = &#039;Z&#039;; $a++;</code> превратит значение переменной <var class="varname">$a</var>
   в значение <code class="literal">«AA»</code>.
  </p>

  <div class="example" id="example-2">
   <p><strong>Пример #2 Пример увеличения строки PERL</strong></p>
   <div class="example-contents">
<div class="annotation-interactive phpcode"><code><span style="color: #000000"><span style="color: #0000BB">&lt;?php<br /><br /></span><span style="color: #007700">echo </span><span style="color: #DD0000">'== Буквенные строки ==' </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">// Буквенно-цифровые строки ведут себя иначе<br /></span><span style="color: #007700">echo </span><span style="color: #DD0000">'== Буквенно-цифровые строки ==' </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 />}</span></span></code></div>
   </div>

   
<div class="example-contents"><p>
 Результат выполнения приведённого примера:
</p></div>

   <div class="example-contents screen">
<div class="annotation-interactive cdata"><pre>
== Буквенные строки ==
X
Y
Z
AA
AB
AC
== Буквенно-цифровые строки ==
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">
    Если буквенно-цифровая строка может быть интерпретирована как
    <a href="language.types.numeric-strings.php" class="link">числовая строка</a>,
    она будет приведена к типу <span class="type"><a href="language.types.integer.php" class="type int">int</a></span> или <span class="type"><a href="language.types.float.php" class="type float">float</a></span>.
    Эта проблема встаёт особенно остро со строками, которые выглядят как числа с плавающей точкой,
    записанные в научной нотации.
    Функция <span class="function"><a href="function.str-increment.php" class="function">str_increment()</a></span> не страдает от эти неявных приведений типов.
   </p>
   <div class="example" id="example-3">
    <p><strong>Пример #3 Буквенно-цифровая строка, преобразованная в число с плавающей точкой</strong></p>
    <div class="example-contents">
<div class="annotation-interactive phpcode"><code><span style="color: #000000"><span style="color: #0000BB">&lt;?php<br /><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">);</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>
     Так происходит потому, что значение <code class="literal">«5e0»</code> было интерпретировано
     как число с плавающей точкой (<span class="type"><a href="language.types.float.php" class="type float">float</a></span>) и приведено к значению <code class="literal">5.0</code>
     перед началом увеличения.
    </p></div>
   </div>
  </div>
 </div>
</div><?php manual_footer($setup); ?>