<?php
include_once $_SERVER['DOCUMENT_ROOT'] . '/include/shared-manual.inc';
$TOC = array();
$TOC_DEPRECATED = array();
$PARENTS = array();
include_once dirname(__FILE__) ."/toc/migration80.inc";
$setup = array (
  'home' => 
  array (
    0 => 'index.php',
    1 => 'PHP Manual',
  ),
  'head' => 
  array (
    0 => 'UTF-8',
    1 => 'ja',
  ),
  'this' => 
  array (
    0 => 'migration80.new-features.php',
    1 => '新機能',
    2 => '新機能',
  ),
  'up' => 
  array (
    0 => 'migration80.php',
    1 => 'PHP 7.4.x から PHP 8.0.x への移行',
  ),
  'prev' => 
  array (
    0 => 'migration80.php',
    1 => 'PHP 7.4.x から PHP 8.0.x への移行',
  ),
  'next' => 
  array (
    0 => 'migration80.new-classes.php',
    1 => '新しいクラスとインターフェイス',
  ),
  'alternatives' => 
  array (
  ),
  'source' => 
  array (
    'lang' => 'ja',
    'path' => 'appendices/migration80/new-features.xml',
  ),
  'history' => 
  array (
  ),
);
$setup["toc"] = $TOC;
$setup["toc_deprecated"] = $TOC_DEPRECATED;
$setup["parents"] = $PARENTS;
manual_setup($setup);

contributors($setup);

?>
<div id="migration80.new-features" class="sect1">
 <h2 class="title">新機能</h2>

 <div class="sect2" id="migration80.new-features.core">
  <h3 class="title">PHP コア</h3>

  <div class="sect3" id="migration80.new-features.core.named-arguments">
   <h4 class="title">名前付き引数</h4>

   <p class="para">
    
    <a href="functions.arguments.php#functions.named-arguments" class="link">名前付き引数</a> のサポートが追加されました。
   </p>
  </div>

  <div class="sect3" id="migration80.new-features.core.attributes">
   <h4 class="title">アトリビュート</h4>

   <p class="para">
    <a href="language.attributes.php" class="link">アトリビュート</a> のサポートが追加されました。
    
    
    
    
   </p>
  </div>

  <div class="sect3" id="migration80.new-features.core.property-promotion">
   <h4 class="title">コンストラクタのプロパティ昇格機能</h4>

   <p class="para">
     <a href="language.oop5.decon.php#language.oop5.decon.constructor.promotion" class="link">コンストラクタの引数をプロパティへ昇格させる機能</a> が追加されました。
    
   </p>
  </div>

  <div class="sect3" id="migration80.new-features.core.union-types">
   <h4 class="title">union 型</h4>

   <p class="para">
    <a href="language.types.declarations.php#language.types.declarations.composite.union" class="link">union 型</a> のサポートが追加されました。
    
   </p> 
  </div>

  <div class="sect3" id="migration80.new-features.core.match">
   <h4 class="title">match 式</h4>

   <p class="para">
    <a href="control-structures.match.php" class="link"><code class="literal">match</code> 式</a> のサポートが追加されました。
    
   </p>
  </div>

  <div class="sect3" id="migration80.new-features.core.nullsafe-operator">
   <h4 class="title">nullsafe 演算子</h4>

   <p class="para">
     <a href="language.oop5.basic.php#language.oop5.basic.nullsafe" class="link">nullsafe 演算子</a> (<code class="literal">?-&gt;</code>) のサポートが追加されました。
    
   </p>
  </div>

  <div class="sect3" id="migration80.new-features.core.others">
   <h4 class="title">その他の新機能</h4>

   <ul class="itemizedlist">
    <li class="listitem">
     <p class="para">
      <a href="class.weakmap.php" class="link">WeakMap</a> クラスが追加されました。
      
     </p>
    </li>
    <li class="listitem">
     <p class="para">
      <span class="classname"><a href="class.valueerror.php" class="classname">ValueError</a></span> クラスが追加されました。
     </p>
    </li>
    <li class="listitem">
     <p class="para">
      任意の数の関数のパラメータが、可変長引数に置き換えられるようになりました。
      但し、型に互換性がある場合に限ります。
      たとえば、次のようなコードが書けるようになります:
     </p>
     <p class="para">
      <div class="example-contents">
<div class="phpcode"><code><span style="color: #000000"><span style="color: #0000BB">&lt;?php<br /></span><span style="color: #007700">class </span><span style="color: #0000BB">A </span><span style="color: #007700">{<br />     public function </span><span style="color: #0000BB">method</span><span style="color: #007700">(</span><span style="color: #0000BB">int $many</span><span style="color: #007700">, </span><span style="color: #0000BB">string $parameters</span><span style="color: #007700">, </span><span style="color: #0000BB">$here</span><span style="color: #007700">) {}<br />}<br />class </span><span style="color: #0000BB">B </span><span style="color: #007700">extends </span><span style="color: #0000BB">A </span><span style="color: #007700">{<br />     public function </span><span style="color: #0000BB">method</span><span style="color: #007700">(...</span><span style="color: #0000BB">$everything</span><span style="color: #007700">) {}<br />}<br /></span><span style="color: #0000BB">?&gt;</span></span></code></div>
      </div>

     </p>
    </li>
    <li class="listitem">
     <p class="para">
      以下のようにして、<span class="type">static</span> (&quot;遅延静的束縛&quot;における) 型が、
      戻り値の型として使えるようになりました:
     </p>
     <p class="para">
      <div class="example-contents">
<div class="phpcode"><code><span style="color: #000000"><span style="color: #0000BB">&lt;?php<br /></span><span style="color: #007700">class </span><span style="color: #0000BB">Test </span><span style="color: #007700">{<br />     public function </span><span style="color: #0000BB">create</span><span style="color: #007700">(): static {<br />          return new static();<br />     }<br />}<br /></span><span style="color: #0000BB">?&gt;</span></span></code></div>
      </div>

      
     </p>
    </li>
    <li class="listitem">
     <p class="para">
      オブジェクトのクラス名を <code class="code">$object::class</code> と書くことで取得できるようになりました。
      この結果は、<code class="code">get_class($object)</code> と同じです。
      
     </p>
    </li>
    <li class="listitem">
     <p class="para">
      <a href="language.oop5.basic.php#language.oop5.basic.new" class="link"><code class="literal">new</code></a> と <a href="language.operators.type.php" class="link"><code class="literal">instanceof</code></a> が、
      <code class="code">new (expression)(...$args)</code> や <code class="code">$obj instanceof (expression)</code>
     という形で、任意の式と一緒に使えるようになりました。
      
     </p>
    </li>
    <li class="listitem">
     <p class="para">
      変数の文法に一貫性を持たせるため、いくつかの修正が適用されます。
      たとえば、<code class="code">Foo::BAR::$baz</code> のような書き方が許可されるようになりました。
      
     </p>
    </li>
    <li class="listitem">
     <p class="para">
      インターフェイス <span class="interfacename"><a href="class.stringable.php" class="interfacename">Stringable</a></span> が追加されました。
      クラスが <a href="language.oop5.magic.php#object.tostring" class="link">__toString()</a> メソッドを定義していた場合、
      このインターフェイスが自動的に実装されます。
      
     </p>
    </li>
    <li class="listitem">
     <p class="para">
      トレイトで、private な抽象メソッドを定義できるようになりました。
      このメソッドは、トレイトを使うクラスで実装されなければなりません。
      
     </p>
    </li>
    <li class="listitem">
     <p class="para">
      <code class="literal">throw</code> が式として使えるようになりました。
      これによって、以下のような書き方ができるようになります:
      <div class="example-contents">
<div class="phpcode"><code><span style="color: #000000"><span style="color: #0000BB">&lt;?php<br />$fn </span><span style="color: #007700">= fn() =&gt; throw new </span><span style="color: #0000BB">Exception</span><span style="color: #007700">(</span><span style="color: #DD0000">'Exception in arrow function'</span><span style="color: #007700">);<br /></span><span style="color: #0000BB">$user </span><span style="color: #007700">= </span><span style="color: #0000BB">$session</span><span style="color: #007700">-&gt;</span><span style="color: #0000BB">user </span><span style="color: #007700">?? throw new </span><span style="color: #0000BB">Exception</span><span style="color: #007700">(</span><span style="color: #DD0000">'Must have user'</span><span style="color: #007700">);</span></span></code></div>
      </div>

      
     </p>
    </li>
    <li class="listitem">
     <p class="para">
      パラメータのリストに付ける最後のカンマも、オプションで許可されるようになりました。
      <div class="example-contents">
<div class="phpcode"><code><span style="color: #000000"><span style="color: #0000BB">&lt;?php<br /></span><span style="color: #007700">function </span><span style="color: #0000BB">functionWithLongSignature</span><span style="color: #007700">(<br />    </span><span style="color: #0000BB">Type1 $parameter1</span><span style="color: #007700">,<br />    </span><span style="color: #0000BB">Type2 $parameter2</span><span style="color: #007700">, </span><span style="color: #FF8000">// &lt;-- このカンマが許可されるようになりました<br /></span><span style="color: #007700">) {<br />}</span></span></code></div>
      </div>

      
     </p>
    </li>
    <li class="listitem">
     <p class="para">
      変数に保存せずに、
      例外をキャッチするために、<code class="code">catch (Exception)</code> というコードが書けるようになりました。
      
     </p>
    </li>
    <li class="listitem">
     <p class="para">
      <span class="type"><a href="language.types.mixed.php" class="type mixed">mixed</a></span> 型のサポートが追加されました。
      
     </p>
    </li>
    <li class="listitem">
     <p class="para">
      親クラスで宣言された private メソッドは、
      子クラスのメソッドに対して継承ルールを強制しなくなりました(
      private final と宣言されたコンストラクタは例外です)。
      次の例は、どういった制限がなくなるのかを示しています:
      <div class="example-contents">
<div class="phpcode"><code><span style="color: #000000"><span style="color: #0000BB">&lt;?php<br /></span><span style="color: #007700">class </span><span style="color: #0000BB">ParentClass </span><span style="color: #007700">{<br />    private function </span><span style="color: #0000BB">method1</span><span style="color: #007700">() {}<br />    private function </span><span style="color: #0000BB">method2</span><span style="color: #007700">() {}<br />    private static function </span><span style="color: #0000BB">method3</span><span style="color: #007700">() {}<br />    </span><span style="color: #FF8000">// "final" が意味をなさなくなったので、警告が発生します:<br />    </span><span style="color: #007700">private final function </span><span style="color: #0000BB">method4</span><span style="color: #007700">() {}<br />}<br />class </span><span style="color: #0000BB">ChildClass </span><span style="color: #007700">extends </span><span style="color: #0000BB">ParentClass </span><span style="color: #007700">{<br />    </span><span style="color: #FF8000">// 親クラスの private メソッドとアクセス権の修飾子が異なっている<br />    // 以下の全ての宣言が許されるようになりました。<br />    </span><span style="color: #007700">public abstract function </span><span style="color: #0000BB">method1</span><span style="color: #007700">() {}<br />    public static function </span><span style="color: #0000BB">method2</span><span style="color: #007700">() {}<br />    public function </span><span style="color: #0000BB">method3</span><span style="color: #007700">() {}<br />    public function </span><span style="color: #0000BB">method4</span><span style="color: #007700">() {}<br />}<br /></span><span style="color: #0000BB">?&gt;</span></span></code></div>
      </div>

      
     </p>
    </li>
    <li class="listitem">
     <p class="para">
      <code class="code">(int) $resource</code> と同じ値を返す <span class="function"><a href="function.get-resource-id.php" class="function">get_resource_id()</a></span> 関数が追加されました。
     よりわかりやすいAPIで、同じ機能を提供するものです。
     </p>
    </li>
    <li class="listitem">
     <p class="para">
      <span class="classname"><a href="class.internaliterator.php" class="classname">InternalIterator</a></span> が追加されました。
     </p>
    </li>
   </ul>
  </div>
 </div>

 <div class="sect2" id="migration80.new-features.date">
  <h3 class="title">日付と時刻</h3>
  
  <ul class="itemizedlist">
   <li class="listitem">
    <p class="para">
     <span class="methodname"><a href="datetime.createfrominterface.php" class="methodname">DateTime::createFromInterface()</a></span> と
     <span class="methodname"><a href="datetimeimmutable.createfrominterface.php" class="methodname">DateTimeImmutable::createFromInterface()</a></span> が追加されました。

    </p>
   </li>
   <li class="listitem">
    <p class="para">
     DateTime のフォーマット指定子 <code class="literal">p</code> が追加されました。
     これは <code class="literal">P</code> と同じですが、
     UTC の <code class="literal">+00:00</code> ではなく、
     <code class="literal">Z</code> を返します。
    </p>
   </li>
  </ul>
 </div>

 <div class="sect2" id="migration80.new-features.dom">
  <h3 class="title">DOM</h3>

  <p class="para">
   新しいDOMの走査と管理を行う API を持つ
   <span class="interfacename"><a href="class.domparentnode.php" class="interfacename">DOMParentNode</a></span> と <span class="interfacename"><a href="class.domchildnode.php" class="interfacename">DOMChildNode</a></span>
   が追加されました。
   
  </p>
 </div>

 <div class="sect2" id="migration80.new-features.filter">
  <h3 class="title">フィルタ</h3>

  <p class="para">
   <strong><code><a href="filter.constants.php#constant.filter-validate-boolean">FILTER_VALIDATE_BOOLEAN</a></code></strong> のエイリアスとして、
   <strong><code><a href="filter.constants.php#constant.filter-validate-bool">FILTER_VALIDATE_BOOL</a></code></strong> が追加されました。
   新しい名前のほうが望ましいです。なぜなら、
   正規化された型の名前を使っているからです。
  </p>
 </div>

 <div class="sect2" id="migration80.new-features.enchant">
  <h3 class="title">Enchant</h3>

  <p class="para">
   <span class="function"><a href="function.enchant-dict-add.php" class="function">enchant_dict_add()</a></span>, <span class="function"><a href="function.enchant-dict-is-added.php" class="function">enchant_dict_is_added()</a></span>,
   <strong><code><a href="enchant.constants.php#constant.libenchant-version">LIBENCHANT_VERSION</a></code></strong> が追加されました。
  </p>
 </div>

 <div class="sect2" id="migration80.new-features.fpm">
  <h3 class="title">FPM</h3>

  <p class="para">
   新しいオプション <code class="literal">pm.status_listen</code> が追加されました。
   これによって、異なるエンドポイント(例: ポートやUDSファイル)から、
   ステータスを取得することが出来るようになります。
   実行時間がかかっているリクエストを処理しているために、全ての子プロセスがビジーである場合、
   ステータスを取得するのに役立ちます。
  </p>
 </div>

 <div class="sect2" id="migration80.new-features.hash">
  <h3 class="title">Hash</h3>

  <p class="para">
   <span class="classname"><a href="class.hashcontext.php" class="classname">HashContext</a></span> オブジェクトが、シリアライズ出来るようになりました。
  </p>
 </div>

 <div class="sect2" id="migration80.new-features.intl">
  <h3 class="title">国際化関数</h3>

  <p class="para">
   定数 <strong><code><a href="class.intldateformatter.php#intldateformatter.constants.relative-full">IntlDateFormatter::RELATIVE_FULL</a></code></strong>,
   <strong><code><a href="class.intldateformatter.php#intldateformatter.constants.relative-long">IntlDateFormatter::RELATIVE_LONG</a></code></strong>,
   <strong><code><a href="class.intldateformatter.php#intldateformatter.constants.relative-medium">IntlDateFormatter::RELATIVE_MEDIUM</a></code></strong>,
   <strong><code><a href="class.intldateformatter.php#intldateformatter.constants.relative-short">IntlDateFormatter::RELATIVE_SHORT</a></code></strong> が追加されました。
  </p>
 </div>

 <div class="sect2" id="migration80.new-features.ldap">
  <h3 class="title">LDAP</h3>

  <p class="para">
   検索結果に含まれる参照メッセージの数を返す <span class="function"><a href="function.ldap-count-references.php" class="function">ldap_count_references()</a></span> が追加されました。
  </p>
 </div>
 <div class="sect2" id="migration80.new-features.opcache">
  <h3 class="title">OPcache</h3>

  <p class="para">
   opcache.record_warnings
   INI ディレクティブが有効になっている場合、
   OPcache はコンパイル時の警告を記録し、次に include されたときにそれを繰り返します。
   これは、たとえキャッシュから情報を得た場合でも同じです。
  </p>
 </div>

 <div class="sect2" id="migration80.new-features.openssl">
  <h3 class="title">OpenSSL</h3>

  <p class="para">
   暗号化メッセージ構文(CMS)
   (<a href="https://datatracker.ietf.org/doc/html/rfc5652" class="link external">&raquo;&nbsp;RFC 5652</a>) のサポートが追加されました。
   これは、暗号化、復号化、署名、検証と読み込みの関数が含まれます。
   API は <abbr title="Public Key Cryptography Standards">PKCS</abbr> #7 の関数と似ていますが、新しいエンコーディングの定数が追加されています:
   <strong><code><a href="openssl.constants.other.php#constant.openssl-encoding-der">OPENSSL_ENCODING_DER</a></code></strong>, <strong><code><a href="openssl.constants.other.php#constant.openssl-encoding-smime">OPENSSL_ENCODING_SMIME</a></code></strong>
   <strong><code><a href="openssl.constants.other.php#constant.openssl-encoding-pem">OPENSSL_ENCODING_PEM</a></code></strong> です。
   <ul class="simplelist">
    <li>
     証明書を使ってファイル中のメッセージを暗号化し、
     結果を指定されたファイルに出力する <span class="function"><a href="function.openssl-cms-encrypt.php" class="function">openssl_cms_encrypt()</a></span> が追加されました。
    </li>
    <li>
     ファイル中の S/MIME メッセージを復号化し、
     結果を指定されたファイルに出力する <span class="function"><a href="function.openssl-cms-decrypt.php" class="function">openssl_cms_decrypt()</a></span> が追加されました。
    </li>
    <li>
     CMSファイルを <abbr title="Privacy-Enhanced Mail">PEM</abbr> 証明書の配列にエクスポートする <span class="function"><a href="function.openssl-cms-read.php" class="function">openssl_cms_read()</a></span> が追加されました。
    </li>
    <li>
     証明書と鍵を使ってファイル中のMIMEメッセージに署名し、
     結果を指定されたファイルに出力する <span class="function"><a href="function.openssl-cms-sign.php" class="function">openssl_cms_sign()</a></span> が追加されました。
    </li>
    <li>
     データブロックが無傷なことや、
     署名した人がその人であることを検証し、
     署名した人の証明書を返す <span class="function"><a href="function.openssl-cms-verify.php" class="function">openssl_cms_verify()</a></span> が追加されました。
    </li>
   </ul>
  </p>
 </div>

 <div class="sect2" id="migration80.new-features.pcre">
  <h3 class="title">正規表現 (Perl互換)</h3>

  <p class="para">
   直近で発生した PCRE に関するエラーを人間が読みやすいメッセージとして返す
   <span class="function"><a href="function.preg-last-error-msg.php" class="function">preg_last_error_msg()</a></span> が追加されました。
   これは、整数の enum を返していた <span class="function"><a href="function.preg-last-error.php" class="function">preg_last_error()</a></span> を補完するものです。
  </p>
 </div>

 <div class="sect2" id="migration80.new-features.reflection">
  <h3 class="title">リフレクション</h3>

  <ul class="itemizedlist">
   <li class="listitem">
    <p class="para">
     以下のメソッドは、内部関数のパラメータのデフォルト値に関する情報を返すようになりました:
    </p>
    <p class="para">
     <ul class="simplelist">
      <li><span class="methodname"><a href="reflectionparameter.isdefaultvalueavailable.php" class="methodname">ReflectionParameter::isDefaultValueAvailable()</a></span></li>
      <li><span class="methodname"><a href="reflectionparameter.getdefaultvalue.php" class="methodname">ReflectionParameter::getDefaultValue()</a></span></li>
      <li><span class="methodname"><a href="reflectionparameter.isdefaultvalueconstant.php" class="methodname">ReflectionParameter::isDefaultValueConstant()</a></span></li>
      <li><span class="methodname"><a href="reflectionparameter.getdefaultvalueconstantname.php" class="methodname">ReflectionParameter::getDefaultValueConstantName()</a></span></li>
     </ul>
    </p>
   </li>
  </ul>
 </div>

 <div class="sect2" id="migration80.new-features.sqlite3">
  <h3 class="title">SQLite3</h3>

  <p class="para">
   データベース上で認証する用途に使う、
   ユーザー空間のコールバックを設定する <span class="methodname"><a href="sqlite3.setauthorizer.php" class="methodname">SQLite3::setAuthorizer()</a></span> と、
   それに対応するクラス定数が追加されました。
   
  </p>
 </div>

 <div class="sect2" id="migration80.new-features.standard">
  <h3 class="title">標準ライブラリ</h3>

  <ul class="itemizedlist">
   <li class="listitem">
    <p class="para">
     文字列に <code class="parameter">needle</code> が含まれているかどうかを調べる
     <span class="function"><a href="function.str-contains.php" class="function">str_contains()</a></span> 関数が追加されました。
    </p>
    <p class="para">
     文字列が <code class="parameter">needle</code> で始まるかを調べる
     <span class="function"><a href="function.str-starts-with.php" class="function">str_starts_with()</a></span> 関数が追加されました。
    </p>
    <p class="para">
     文字列が <code class="parameter">needle</code> で終わるかを調べる
     <span class="function"><a href="function.str-ends-with.php" class="function">str_ends_with()</a></span> 関数が追加されました。
     
     
    </p>
   </li>
   <li class="listitem">
    <p class="para">
     IEEE 754 のセマンティクスに沿って浮動小数点数の割り算を行う
     <span class="function"><a href="function.fdiv.php" class="function">fdiv()</a></span> 関数が追加されました。
     ゼロ除算は、well-defined とみなされ、
     <code class="literal">Inf</code>,
     <code class="literal">-Inf</code>, <code class="literal">NaN</code> のいずれかを返します。
    </p>
   </li>
   <li class="listitem">
    <p class="para">
     エラーメッセージで使うのに便利な型を返す
     <span class="function"><a href="function.get-debug-type.php" class="function">get_debug_type()</a></span> 関数が追加されました。
     <span class="function"><a href="function.gettype.php" class="function">gettype()</a></span> と違うのは、
     この関数は正規化された型の名前を使い、オブジェクトのときはクラス名を返し、
     リソースの場合はリソースのタイプを示すことです。
     
    </p>
   </li>
   <li class="listitem">
    <p class="para">
     <span class="function"><a href="function.printf.php" class="function">printf()</a></span> 関数とその仲間の関数は、
     フォーマット指定子 <code class="literal">%h</code> と <code class="literal">%H</code> をサポートしました。
     これらは <code class="literal">%g</code> および <code class="literal">%G</code> と同じですが、
     10進数の区切り文字を <strong><code><a href="string.constants.php#constant.lc-numeric">LC_NUMERIC</a></code></strong> ロケールによって決めるのではなく、
     常に <code class="literal">&quot;.&quot;</code> を使います。
    </p>
   </li>
   <li class="listitem">
    <p class="para">
     <span class="function"><a href="function.printf.php" class="function">printf()</a></span> 関数とその仲間の関数は、
     精度または広さを指定する用途のために <code class="literal">&quot;*&quot;</code> をサポートしました。
     この場合、精度/広さは printf の引数として渡します。
     精度として <code class="literal">-1</code> を <code class="literal">%g</code>, <code class="literal">%G</code>,
     <code class="literal">%h</code>,  <code class="literal">%H</code> に指定することも出来ます。
     たとえば、次のコードで、PHP のデフォルトの浮動小数点のフォーマットを再現することができます:
    </p>
    <p class="para">
     <div class="example-contents">
<div class="phpcode"><code><span style="color: #000000"><span style="color: #0000BB">&lt;?php<br />printf</span><span style="color: #007700">(</span><span style="color: #DD0000">"%.*H"</span><span style="color: #007700">, (int) </span><span style="color: #0000BB">ini_get</span><span style="color: #007700">(</span><span style="color: #DD0000">"precision"</span><span style="color: #007700">), </span><span style="color: #0000BB">$float</span><span style="color: #007700">);<br /></span><span style="color: #0000BB">printf</span><span style="color: #007700">(</span><span style="color: #DD0000">"%.*H"</span><span style="color: #007700">, (int) </span><span style="color: #0000BB">ini_get</span><span style="color: #007700">(</span><span style="color: #DD0000">"serialize_precision"</span><span style="color: #007700">), </span><span style="color: #0000BB">$float</span><span style="color: #007700">);<br /></span><span style="color: #0000BB">?&gt;</span></span></code></div>
     </div>

    </p>
   </li>
   <li class="listitem">
    <p class="para">
     <span class="function"><a href="function.proc-open.php" class="function">proc_open()</a></span> に、疑似端末(PTY) ディスクリプタのサポートが追加されました。
     以下のコードは、
     <code class="literal">stdin</code>, <code class="literal">stdout</code>, <code class="literal">stderr</code>
     を同じPTYにアタッチします:
    </p>
    <p class="para">
     <div class="example-contents">
<div class="phpcode"><code><span style="color: #000000"><span style="color: #0000BB">&lt;?php<br />$proc </span><span style="color: #007700">= </span><span style="color: #0000BB">proc_open</span><span style="color: #007700">(</span><span style="color: #0000BB">$command</span><span style="color: #007700">, [[</span><span style="color: #DD0000">'pty'</span><span style="color: #007700">], [</span><span style="color: #DD0000">'pty'</span><span style="color: #007700">], [</span><span style="color: #DD0000">'pty'</span><span style="color: #007700">]], </span><span style="color: #0000BB">$pipes</span><span style="color: #007700">);<br /></span><span style="color: #0000BB">?&gt;</span></span></code></div>
     </div>

    </p>
   </li>
   <li class="listitem">
    <p class="para">
     <span class="function"><a href="function.proc-open.php" class="function">proc_open()</a></span> 関数は、
     ソケットペアのディスクリプタをサポートするようになりました。
     以下のコードは、異なるソケットペアを
     <code class="literal">stdin</code>, <code class="literal">stdout</code>,
     <code class="literal">stderr</code> にアタッチします:
    </p>
    <p class="para">
     <div class="example-contents">
<div class="phpcode"><code><span style="color: #000000"><span style="color: #0000BB">&lt;?php<br />$proc </span><span style="color: #007700">= </span><span style="color: #0000BB">proc_open</span><span style="color: #007700">(</span><span style="color: #0000BB">$command</span><span style="color: #007700">, [[</span><span style="color: #DD0000">'socket'</span><span style="color: #007700">], [</span><span style="color: #DD0000">'socket'</span><span style="color: #007700">], [</span><span style="color: #DD0000">'socket'</span><span style="color: #007700">]], </span><span style="color: #0000BB">$pipes</span><span style="color: #007700">);<br /></span><span style="color: #0000BB">?&gt;</span></span></code></div>
     </div>

    </p>
    <p class="para">
     Windows では、パイプと異なり、ソケットは ブロッキングI/O の問題の影響を受けません。
     しかし、全てのプログラムが標準入出力のソケットで正しく動くとは限りません。
    </p>
   </li>
   <li class="listitem">
    <p class="para">
     ソート関数が安定ソートになりました。
     これは、比較して等しいと判定された要素は、もともとの順序を維持するということです。
     
    </p>
   </li>
   <li class="listitem">
    <p class="para">
     <span class="function"><a href="function.array-diff.php" class="function">array_diff()</a></span>, <span class="function"><a href="function.array-intersect.php" class="function">array_intersect()</a></span> や、
     そのバリエーションの関数は、単一の配列を引数に取れるようになりました。
     これによって、以下のような使い方が出来るようになるということです:
    </p>
    <p class="para">
     <div class="example-contents">
<div class="phpcode"><code><span style="color: #000000"><span style="color: #0000BB">&lt;?php<br /></span><span style="color: #FF8000">//  $excludes が空でも問題ありません:<br /></span><span style="color: #0000BB">array_diff</span><span style="color: #007700">(</span><span style="color: #0000BB">$array</span><span style="color: #007700">, ...</span><span style="color: #0000BB">$excludes</span><span style="color: #007700">);<br /></span><span style="color: #FF8000">//  $arrays が 単一の配列だけを含んでいても問題ありません:<br /></span><span style="color: #0000BB">array_intersect</span><span style="color: #007700">(...</span><span style="color: #0000BB">$arrays</span><span style="color: #007700">);<br /></span><span style="color: #0000BB">?&gt;</span></span></code></div>
     </div>

    </p>
   </li>
   <li class="listitem">
    <p class="para">
     <span class="function"><a href="function.ob-implicit-flush.php" class="function">ob_implicit_flush()</a></span> 関数の <code class="parameter">flag</code>
     パラメータが、<span class="type"><a href="language.types.integer.php" class="type int">int</a></span> ではなく <span class="type"><a href="language.types.boolean.php" class="type bool">bool</a></span> を受け取るように変更されました。
    </p>
   </li>
  </ul>
 </div>

 <div class="sect2" id="migration80.new-features.tokenizer">
  <h3 class="title">Tokenizer</h3>

  <p class="para">
   <span class="classname"><a href="class.phptoken.php" class="classname">PhpToken</a></span> クラスは、
   オブジェクトベースのインターフェイスを tokenizer に追加します。
   このクラスは、統一された、人間工学に基づいた表現を提供しながら、
   メモリ効率がよく、高速になっています。
   
  </p>
 </div>

 <div class="sect2" id="migration80.new-features.zip">
  <h3 class="title">Zip</h3>

  <ul class="itemizedlist">
   <li class="listitem">
    <p class="para">
     Zip 拡張モジュールが、1.19.1 に更新されました。
    </p>
   </li>
   <li class="listitem">
    <p class="para">
     エントリの変更時間を設定するための
     <span class="methodname"><a href="ziparchive.setmtimename.php" class="methodname">ZipArchive::setMtimeName()</a></span>,
     <span class="methodname"><a href="ziparchive.setmtimeindex.php" class="methodname">ZipArchive::setMtimeIndex()</a></span> が追加されました。
    </p>
   </li>
   <li class="listitem">
    <p class="para">
     アーカイブがクローズされている間に行われた更新情報を提供する
     <span class="methodname"><a href="ziparchive.registerprogresscallback.php" class="methodname">ZipArchive::registerProgressCallback()</a></span> が追加されました。
    </p>
   </li>
   <li class="listitem">
    <p class="para">
     アーカイブがクローズされている間にキャンセルを許可する
     <span class="methodname"><a href="ziparchive.registercancelcallback.php" class="methodname">ZipArchive::registerCancelCallback()</a></span> が追加されました。
    </p>
   </li>
   <li class="listitem">
    <p class="para">
     エントリの内容を置換する
     <span class="methodname"><a href="ziparchive.replacefile.php" class="methodname">ZipArchive::replaceFile()</a></span> が追加されました。
    </p>
   </li>
   <li class="listitem">
    <p class="para">
     オプションの圧縮機能がサポートされているかをチェックする
     <span class="methodname"><a href="ziparchive.iscompressionmethoddupported.php" class="methodname">ZipArchive::isCompressionMethodSupported()</a></span> が追加されました。
    </p>
   </li>
   <li class="listitem">
    <p class="para">
     オプションの暗号化機能がサポートされているかをチェックする
     <span class="methodname"><a href="ziparchive.isencryptionmethoddupported.php" class="methodname">ZipArchive::isEncryptionMethodSupported()</a></span> が追加されました。
    </p>
   </li>
   <li class="listitem">
    <p class="para">
     最後に追加されたエントリのインデックスの値を取得するために、
     <var class="varname">ZipArchive::lastId</var> が追加されました。
    </p>
   </li>
   <li class="listitem">
    <p class="para">
     <var class="varname">ZipArchive::status</var> や
     <var class="varname">ZipArchive::statusSys</var> プロパティ、
     または <span class="methodname"><a href="ziparchive.getstatusstring.php" class="methodname">ZipArchive::getStatusString()</a></span> メソッドを使って、
     アーカイブがクローズされた後でもエラーをチェックできるようになりました。
    </p>
   </li>
   <li class="listitem">
    <p class="para">
     <span class="methodname"><a href="ziparchive.addglob.php" class="methodname">ZipArchive::addGlob()</a></span> と
     <span class="methodname"><a href="ziparchive.addpattern.php" class="methodname">ZipArchive::addPattern()</a></span> メソッドの
     <code class="literal">&#039;remove_path&#039;</code> オプションは、
     (<code class="literal">&#039;add_path&#039;</code> オプションと一貫性を保つため)
     任意の文字列のプレフィックスとして扱われるようになりました。
     これより前のバージョンでは、デイレクトリ名として扱われていました。
    </p>
   </li>
   <li class="listitem">
    <p class="para">
     オプションの 圧縮/伸長 機能が phpinfo でも一覧できるようになりました。
    </p>
   </li>
  </ul>
 </div>

</div><?php manual_footer($setup); ?>