<?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 => 'pt_BR',
  ),
  'this' => 
  array (
    0 => 'migration80.new-features.php',
    1 => 'Novas Funcionalidades',
    2 => 'Novas Funcionalidades',
  ),
  'up' => 
  array (
    0 => 'migration80.php',
    1 => 'Migrando do PHP 7.4.x para o PHP 8.0.x',
  ),
  'prev' => 
  array (
    0 => 'migration80.php',
    1 => 'Migrando do PHP 7.4.x para o PHP 8.0.x',
  ),
  'next' => 
  array (
    0 => 'migration80.new-classes.php',
    1 => 'Novas Classes e Interfaces',
  ),
  'alternatives' => 
  array (
  ),
  'source' => 
  array (
    'lang' => 'pt_BR',
    '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">Novas Funcionalidades</h2>

 <div class="sect2" id="migration80.new-features.core">
  <h3 class="title">Núcleo do PHP</h3>

  <div class="sect3" id="migration80.new-features.core.named-arguments">
   <h4 class="title">Argumentos nomeados</h4>

   <p class="para">
    
    O suporte para <a href="functions.arguments.php#functions.named-arguments" class="link">Argumentos nomeados</a> foi adicionado.
   </p>
  </div>

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

   <p class="para">
    Suporte para <a href="language.attributes.php" class="link">Atributos</a> foi adicionado.
    
    
    
    
   </p>
  </div>

  <div class="sect3" id="migration80.new-features.core.property-promotion">
   <h4 class="title">Promoção de propriedade do construtor</h4>

   <p class="para">
    Suporte para <a href="language.oop5.decon.php#language.oop5.decon.constructor.promotion" class="link">promoção de propriedade do construtor</a> (declarando propriedades na assinatura do construtor)
    foi adicionado.
    
   </p>
  </div>

  <div class="sect3" id="migration80.new-features.core.union-types">
   <h4 class="title">União de Tipos</h4>

   <p class="para">
    O suporte para <a href="language.types.declarations.php#language.types.declarations.composite.union" class="link">união de tipos</a> foi adicionado.
    
   </p>
  </div>

  <div class="sect3" id="migration80.new-features.core.match">
   <h4 class="title">Expressão Match</h4>

   <p class="para">
    O suporte para <a href="control-structures.match.php" class="link">expressões <code class="literal">match</code></a> foi adicionado.
    
   </p>
  </div>

  <div class="sect3" id="migration80.new-features.core.nullsafe-operator">
   <h4 class="title">Operador Nullsafe</h4>

   <p class="para">
    Suporte para o <a href="language.oop5.basic.php#language.oop5.basic.nullsafe" class="link">nullsafe operador</a> (<code class="literal">?-&gt;</code>) foi adicionado.
    
   </p>
  </div>

  <div class="sect3" id="migration80.new-features.core.others">
   <h4 class="title">Outros novos recursos</h4>

   <ul class="itemizedlist">
    <li class="listitem">
     <p class="para">
      A classe <a href="class.weakmap.php" class="link">WeakMap</a> foi adicionada.
      
     </p>
    </li>
    <li class="listitem">
     <p class="para">
      A classe <span class="classname"><a href="class.valueerror.php" class="classname">ValueError</a></span> foi adicionada.
     </p>
    </li>
    <li class="listitem">
     <p class="para">
      Qualquer número de parâmetros de função agora pode ser substituído por um argumento variádico, desde que os
      tipos sejam compatíveis. Por exemplo, o seguinte código agora é permitido:
     </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> (como em &quot;vinculação estática tardia&quot;) agora pode ser usado como um tipo de retorno:
     </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">
      Agora é possível buscar o nome da classe de um objeto usando
      <code class="code">$object::class</code>. O resultado é o mesmo que <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> e <a href="language.operators.type.php" class="link"><code class="literal">instanceof</code></a> agora podem ser usados com expressões arbitrárias,
      usando <code class="code">new (expression)(...$args)</code> e <code class="code">$obj instanceof (expression)</code>.
      
     </p>
    </li>
    <li class="listitem">
     <p class="para">
      Algumas correções de consistência na sintaxe da variável foram aplicadas, por exemplo, escrever
      <code class="code">Foo::BAR::$baz</code> agora é permitido.
      
     </p>
    </li>
    <li class="listitem">
     <p class="para">
      Adicionada interface <span class="interfacename"><a href="class.stringable.php" class="interfacename">Stringable</a></span>, que é implementada automaticamente se
      uma classe definir um método <a href="language.oop5.magic.php#object.tostring" class="link">__toString()</a>.
      
     </p>
    </li>
    <li class="listitem">
     <p class="para">
      As Traits agora podem definir métodos privados abstratos.
      Tais métodos devem ser implementados pela classe que usa o trait.
      
     </p>
    </li>
    <li class="listitem">
     <p class="para">
      <code class="literal">throw</code> agora pode ser usado como uma expressão.
      Isso permite usos como:
      <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">'Exceção na função de seta'</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">'É necessário haver um usuário.'</span><span style="color: #007700">);</span></span></code></div>
      </div>

      
     </p>
    </li>
    <li class="listitem">
     <p class="para">
      Uma vírgula final opcional agora é permitida nas listas de parâmetros.
      <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;-- Esta vírgula agora é permitida.<br /></span><span style="color: #007700">) {<br />}</span></span></code></div>
      </div>

      
     </p>
    </li>
    <li class="listitem">
     <p class="para">
      Agora é possível escrever <code class="code">catch (Exception)</code> para capturar uma exceção sem armazená-la
      em uma variável.
      
     </p>
    </li>
    <li class="listitem">
     <p class="para">
      O suporte para tipo <span class="type"><a href="language.types.mixed.php" class="type mixed">mixed</a></span> foi adicionado.
      
     </p>
    </li>
    <li class="listitem">
     <p class="para">
      Os métodos privados declarados em uma classe pai não impõem mais nenhuma regra de herança nos métodos
      de uma classe filha (com exceção dos construtores privados finais).
      O exemplo a seguir ilustra quais restrições foram removidas:
      <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">// Lança um aviso, pois "final" não tem mais efeito:<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">// Todos os itens a seguir agora são permitidos, mesmo que os modificadores não sejam<br />    // o mesmo que para os métodos privados na classe pai.<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">
      <span class="function"><a href="function.get-resource-id.php" class="function">get_resource_id()</a></span> foi adicionado, o que retorna o mesmo valor que
      <code class="code">(int) $resource</code>. Ele fornece a mesma funcionalidade em uma API mais clara.
     </p>
    </li>
    <li class="listitem">
     <p class="para">
      O <span class="classname"><a href="class.internaliterator.php" class="classname">InternalIterator</a></span> foi adicionado.
     </p>
    </li>
   </ul>
  </div>
 </div>

 <div class="sect2" id="migration80.new-features.date">
  <h3 class="title">Data e hora</h3>

  <ul class="itemizedlist">
   <li class="listitem">
    <p class="para">
     <span class="methodname"><a href="datetime.createfrominterface.php" class="methodname">DateTime::createFromInterface()</a></span> e
     <span class="methodname"><a href="datetimeimmutable.createfrominterface.php" class="methodname">DateTimeImmutable::createFromInterface()</a></span> foram adicionados.
    </p>
   </li>
   <li class="listitem">
    <p class="para">
     O especificador de formato DateTime <code class="literal">p</code> foi adicionado, que é o mesmo que
     <code class="literal">P</code>, mas retorna <code class="literal">Z</code> em vez de <code class="literal">+00:00</code>
     para UTC.
    </p>
   </li>
  </ul>
 </div>

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

  <p class="para">
   <span class="interfacename"><a href="class.domparentnode.php" class="interfacename">DOMParentNode</a></span> e <span class="interfacename"><a href="class.domchildnode.php" class="interfacename">DOMChildNode</a></span> com
   novas APIs de travessia e manipulação foram adicionadas.
   
  </p>
 </div>

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

  <p class="para">
   <strong><code><a href="filter.constants.php#constant.filter-validate-bool">FILTER_VALIDATE_BOOL</a></code></strong> foi adicionado como um alias para
   <strong><code><a href="filter.constants.php#constant.filter-validate-boolean">FILTER_VALIDATE_BOOLEAN</a></code></strong>. O novo nome é preferido, pois usa o nome do
   tipo canônico.
  </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> e
   <strong><code><a href="enchant.constants.php#constant.libenchant-version">LIBENCHANT_VERSION</a></code></strong>foram adicionados.chant
  </p>
 </div>

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

  <p class="para">
   Adicionada uma nova opção <code class="literal">pm.status_listen</code> que permite obter o status de um
   terminal diferente (por exemplo, porta ou arquivo UDS), o que é útil para obter o status
   quando todos os filhos estão ocupados atendendo a solicitações de execução longa.
  </p>
 </div>

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

  <p class="para">
   Os objetos <span class="classname"><a href="class.hashcontext.php" class="classname">HashContext</a></span> agora podem ser serializados.
  </p>
 </div>

 <div class="sect2" id="migration80.new-features.intl">
  <h3 class="title">Funções de Internacionalização</h3>

  <p class="para">
   As constantes <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> e
   <strong><code><a href="class.intldateformatter.php#intldateformatter.constants.relative-short">IntlDateFormatter::RELATIVE_SHORT</a></code></strong>
   foram adicionadas.
  </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> foi adicionado, o que retorna o número
   de mensagens de referência em um resultado de pesquisa.
  </p>
 </div>
 <div class="sect2" id="migration80.new-features.opcache">
  <h3 class="title">OPcache</h3>

  <p class="para">
   Se a configuração ini opcache.record_warnings estiver
   habilitada, o OPcache gravará avisos em tempo de compilação e os reproduzirá na próxima inclusão, mesmo que
   seja servido do cache.
  </p>
 </div>

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

  <p class="para">
   Adicionado suporte de sintaxe de mensagem criptográfica (CMS) (<a href="https://datatracker.ietf.org/doc/html/rfc5652" class="link external">&raquo;&nbsp;RFC 5652</a>)
   composto de funções para criptografia, descriptografia, assinatura, verificação e leitura. A API
   é semelhante à API para funções <abbr title="Public Key Cryptography Standards">PKCS</abbr> #7 com a adição de novas constantes de codificação:
   <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>
   e <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> criptografa a mensagem no arquivo com os certificados e
     gera o resultado no arquivo fornecido.
    </li>
    <li>
     <span class="function"><a href="function.openssl-cms-decrypt.php" class="function">openssl_cms_decrypt()</a></span> descriptografa a mensagem S/MIME no arquivo e envia
     os resultados para o arquivo fornecido.
    </li>
    <li>
     <span class="function"><a href="function.openssl-cms-read.php" class="function">openssl_cms_read()</a></span> exporta o arquivo CMS para um array de
     certificados <abbr title="Privacy-Enhanced Mail">PEM</abbr>.
    </li>
    <li>
     <span class="function"><a href="function.openssl-cms-sign.php" class="function">openssl_cms_sign()</a></span> assina a mensagem MIME no arquivo com um certificado e
     uma chave e gera o resultado no arquivo fornecido.
    </li>
    <li>
     <span class="function"><a href="function.openssl-cms-verify.php" class="function">openssl_cms_verify()</a></span> verifica se o bloco de dados está intacto, o signatário
     é quem diz ser e retorna os certificados dos signatários.
    </li>
   </ul>
  </p>
 </div>

 <div class="sect2" id="migration80.new-features.pcre">
  <h3 class="title">Expressões Regulares (Compatíveis com Perl)</h3>

  <p class="para">
   <span class="function"><a href="function.preg-last-error-msg.php" class="function">preg_last_error_msg()</a></span> foi adicionada, que retorna uma mensagem legível por humanos para o último
   erro PCRE. Ela complementa <span class="function"><a href="function.preg-last-error.php" class="function">preg_last_error()</a></span>, que retorna um valor de enumeração
   inteiro.
  </p>
 </div>

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

  <ul class="itemizedlist">
   <li class="listitem">
    <p class="para">
     Os seguintes métodos agora podem retornar informações sobre valores padrão
     de parâmetros de funções internas:
    </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> e respectivas constantes de classe foram adicionados
   para definir um callback userland que será usado para autorizar ou não uma ação no banco de dados.
   
  </p>
 </div>

 <div class="sect2" id="migration80.new-features.standard">
  <h3 class="title">Biblioteca padrão</h3>

  <ul class="itemizedlist">
   <li class="listitem">
    <p class="para">
     <span class="function"><a href="function.str-contains.php" class="function">str_contains()</a></span>, <span class="function"><a href="function.str-starts-with.php" class="function">str_starts_with()</a></span> e
     <span class="function"><a href="function.str-ends-with.php" class="function">str_ends_with()</a></span> foram adicionados, que verificam se <code class="parameter">haystack</code> contém,
     começa com ou termina com <code class="parameter">needle</code>, respectivamente.
     
     
    </p>
   </li>
   <li class="listitem">
    <p class="para">
     <span class="function"><a href="function.fdiv.php" class="function">fdiv()</a></span> foi adicionado, que executa uma divisão de ponto flutuante sob a semântica IEEE 754.
     A divisão por zero é considerada bem definida e retornará um de <code class="literal">Inf</code>,
     <code class="literal">-Inf</code> ou <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> foi adicionado, o que retorna um tipo útil para mensagens de erro. Ao contrário de
     <span class="function"><a href="function.gettype.php" class="function">gettype()</a></span>, ele usa nomes de tipo canônico, retorna nomes de classe para objetos e
     indica o tipo de recurso para recursos.
     
    </p>
   </li>
   <li class="listitem">
    <p class="para">
     <span class="function"><a href="function.printf.php" class="function">printf()</a></span> e amigos agora suportam os especificadores de formato <code class="literal">%h</code> e
     <code class="literal">%H</code>. Estes são os mesmos que <code class="literal">%g</code> e
     <code class="literal">%G</code>, mas sempre use <code class="literal">&quot;.&quot;</code> como o separador decimal, em vez
     de determiná-lo por meio da localidade <strong><code><a href="string.constants.php#constant.lc-numeric">LC_NUMERIC</a></code></strong>.
    </p>
   </li>
   <li class="listitem">
    <p class="para">
     <span class="function"><a href="function.printf.php" class="function">printf()</a></span> e amigos agora suportam o uso de <code class="literal">&quot;*&quot;</code> como largura
     ou precisão, caso em que a largura/precisão é passada como um argumento para printf. Isso também permite
     usar a precisão <code class="literal">-1</code> com <code class="literal">%g</code>, <code class="literal">%G</code>,
     <code class="literal">%h</code> e <code class="literal">%H</code>. Por exemplo, o código a seguir pode ser usado para
     reproduzir a formatação de ponto flutuante padrão do 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> agora suporta descritores pseudo-terminal (PTY). O seguinte
     anexa <code class="literal">stdin</code>, <code class="literal">stdout</code> e <code class="literal">stderr</code> ao
     mesmo 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> agora suporta descritores de pares de sockets. O seguinte anexa
     um par de sockets distinto a <code class="literal">stdin</code>, <code class="literal">stdout</code> e
     <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">
     Ao contrário dos pipes, os sockets não sofrem com problemas de bloqueio de E/S no Windows.
     No entanto, nem todos os programas podem funcionar corretamente com soquetes stdio.
    </p>
   </li>
   <li class="listitem">
    <p class="para">
     As funções de classificação agora são estáveis, o que significa que os elementos de comparação igual
     manterão sua ordem original.
     
    </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> e suas variações agora podem
     ser usadas com um único array como argumento. Isso significa que usos como os seguintes agora são
     possíveis:
    </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">// OK, mesmo que $excludes esteja vazio:<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">// OK, mesmo que $arrays contenha apenas um único array:<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">
     O parâmetro <code class="parameter">flag</code> de <span class="function"><a href="function.ob-implicit-flush.php" class="function">ob_implicit_flush()</a></span> foi alterado
     para aceitar um <span class="type"><a href="language.types.boolean.php" class="type bool">bool</a></span> em vez de um <span class="type"><a href="language.types.integer.php" class="type int">int</a></span>.
    </p>
   </li>
  </ul>
 </div>

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

  <p class="para">
   <span class="classname"><a href="class.phptoken.php" class="classname">PhpToken</a></span> adiciona uma interface baseada em objeto ao tokenizer. Ele fornece uma
   representação mais uniforme e ergonômica, além de ser mais eficiente em termos de memória e mais rápido.
   
  </p>
 </div>

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

  <ul class="itemizedlist">
   <li class="listitem">
    <p class="para">
     A extensão Zip foi atualizada para a versão 1.19.1.
    </p>
   </li>
   <li class="listitem">
    <p class="para">
     Novo <span class="methodname"><a href="ziparchive.setmtimename.php" class="methodname">ZipArchive::setMtimeName()</a></span> e
     <span class="methodname"><a href="ziparchive.setmtimeindex.php" class="methodname">ZipArchive::setMtimeIndex()</a></span> para definir a hora de modificação de uma entrada.
    </p>
   </li>
   <li class="listitem">
    <p class="para">
     Novo <span class="methodname"><a href="ziparchive.registerprogresscallback.php" class="methodname">ZipArchive::registerProgressCallback()</a></span> para fornecer atualizações durante o fechamento do arquivo.
    </p>
   </li>
   <li class="listitem">
    <p class="para">
     Novo <span class="methodname"><a href="ziparchive.registercancelcallback.php" class="methodname">ZipArchive::registerCancelCallback()</a></span> para permitir o cancelamento durante o fechamento
     do arquivo.
    </p>
   </li>
   <li class="listitem">
    <p class="para">
     Novo <span class="methodname"><a href="ziparchive.replacefile.php" class="methodname">ZipArchive::replaceFile()</a></span> para substituir um conteúdo de entrada.
    </p>
   </li>
   <li class="listitem">
    <p class="para">
     Novo <span class="methodname"><a href="ziparchive.iscompressionmethoddupported.php" class="methodname">ZipArchive::isCompressionMethodSupported()</a></span> para verificar os recursos opcionais de
     compactação.
    </p>
   </li>
   <li class="listitem">
    <p class="para">
     Novo <span class="methodname"><a href="ziparchive.isencryptionmethoddupported.php" class="methodname">ZipArchive::isEncryptionMethodSupported()</a></span> para verificar os recursos opcionais de
     criptografia.
    </p>
   </li>
   <li class="listitem">
    <p class="para">
     A propriedade <var class="varname">ZipArchive::lastId</var> para obter o valor do índice da
     última entrada adicionada foi adicionada.
    </p>
   </li>
   <li class="listitem">
    <p class="para">
     Os erros agora podem ser verificados após o fechamento de um arquivo usando as propriedades
     <var class="varname">ZipArchive::status</var> e
     <var class="varname">ZipArchive::statusSys</var> ou o método
     <span class="methodname"><a href="ziparchive.getstatusstring.php" class="methodname">ZipArchive::getStatusString()</a></span>.
    </p>
   </li>
   <li class="listitem">
    <p class="para">
     A opção <code class="literal">&#039;remove_path&#039;</code> de <span class="methodname"><a href="ziparchive.addglob.php" class="methodname">ZipArchive::addGlob()</a></span> e
     <span class="methodname"><a href="ziparchive.addpattern.php" class="methodname">ZipArchive::addPattern()</a></span> agora é tratada como um prefixo de string arbitrário (para
     consistência com a opção <code class="literal">&#039;add_path&#039;</code>), enquanto anteriormente era tratada como um
     nome de diretório.
    </p>
   </li>
   <li class="listitem">
    <p class="para">
     Os recursos opcionais de compactação/criptografia agora estão listados no phpinfo.
    </p>
   </li>
  </ul>
 </div>

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