<?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 => 'ja',
  ),
  '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' => 'ja',
    '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 /></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">);<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>
後置加算:
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> が発生するようになりました。なぜなら、bool 型の値を暗黙のうちに数値型にキャストするように将来変更されるからです。
   </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> が発生するようになりました。なぜなら、null 型の値を暗黙のうちに数値型にキャストするように将来変更されるからです。
   </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 以降は soft-deprecated 扱い
    (<strong><code><a href="errorfunc.constants.php#constant.e-deprecated">E_DEPRECATED</a></code></strong> は発生しないものの、新しいコードではこの機能を使うべきではない) になっています。
    <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">&#039;AA&#039;</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 /></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 />}<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>
== アルファベットからなる文字列 ==
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 />$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>
     上記の出力になる理由は、<code class="literal">&quot;5e0&quot;</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); ?>