<?php
include_once $_SERVER['DOCUMENT_ROOT'] . '/include/shared-manual.inc';
$TOC = array();
$TOC_DEPRECATED = array();
$PARENTS = array();
include_once dirname(__FILE__) ."/toc/ref.stream.inc";
$setup = array (
  'home' => 
  array (
    0 => 'index.php',
    1 => 'PHP Manual',
  ),
  'head' => 
  array (
    0 => 'UTF-8',
    1 => 'pt_BR',
  ),
  'this' => 
  array (
    0 => 'function.stream-select.php',
    1 => 'stream_select',
    2 => 'Executa o equivalente &agrave; chamada de sistema select() nos arrays de fluxos
   informados com um limite de tempo especificado por segundos e microssegundos',
  ),
  'up' => 
  array (
    0 => 'ref.stream.php',
    1 => 'Fun&ccedil;&otilde;es de Fluxo',
  ),
  'prev' => 
  array (
    0 => 'function.stream-resolve-include-path.php',
    1 => 'stream_resolve_include_path',
  ),
  'next' => 
  array (
    0 => 'function.stream-set-blocking.php',
    1 => 'stream_set_blocking',
  ),
  'alternatives' => 
  array (
  ),
  'source' => 
  array (
    'lang' => 'pt_BR',
    'path' => 'reference/stream/functions/stream-select.xml',
  ),
  'history' => 
  array (
  ),
);
$setup["toc"] = $TOC;
$setup["toc_deprecated"] = $TOC_DEPRECATED;
$setup["parents"] = $PARENTS;
manual_setup($setup);

contributors($setup);

?>
<div id="function.stream-select" class="refentry">
 <div class="refnamediv">
  <h1 class="refname">stream_select</h1>
  <p class="verinfo">(PHP 4 &gt;= 4.3.0, PHP 5, PHP 7, PHP 8)</p><p class="refpurpose"><span class="refname">stream_select</span> &mdash; <span class="dc-title">Executa o equivalente à chamada de sistema select() nos arrays de fluxos
   informados com um limite de tempo especificado por segundos e microssegundos</span></p>

 </div>
 <div class="refsect1 description" id="refsect1-function.stream-select-description">
  <h3 class="title">Descrição</h3>
  <div class="methodsynopsis dc-description">
   <span class="methodname"><strong>stream_select</strong></span>(<br>&nbsp;&nbsp;&nbsp;&nbsp;<span class="methodparam"><span class="type"><span class="type"><a href="language.types.null.php" class="type null">?</a></span><span class="type"><a href="language.types.array.php" class="type array">array</a></span></span> <code class="parameter reference">&$read</code></span>,<br>&nbsp;&nbsp;&nbsp;&nbsp;<span class="methodparam"><span class="type"><span class="type"><a href="language.types.null.php" class="type null">?</a></span><span class="type"><a href="language.types.array.php" class="type array">array</a></span></span> <code class="parameter reference">&$write</code></span>,<br>&nbsp;&nbsp;&nbsp;&nbsp;<span class="methodparam"><span class="type"><span class="type"><a href="language.types.null.php" class="type null">?</a></span><span class="type"><a href="language.types.array.php" class="type array">array</a></span></span> <code class="parameter reference">&$except</code></span>,<br>&nbsp;&nbsp;&nbsp;&nbsp;<span class="methodparam"><span class="type"><span class="type"><a href="language.types.null.php" class="type null">?</a></span><span class="type"><a href="language.types.integer.php" class="type int">int</a></span></span> <code class="parameter">$seconds</code></span>,<br>&nbsp;&nbsp;&nbsp;&nbsp;<span class="methodparam"><span class="type"><span class="type"><a href="language.types.null.php" class="type null">?</a></span><span class="type"><a href="language.types.integer.php" class="type int">int</a></span></span> <code class="parameter">$microseconds</code><span class="initializer"> = <strong><code><a href="reserved.constants.php#constant.null">null</a></code></strong></span></span><br>): <span class="type"><span class="type"><a href="language.types.integer.php" class="type int">int</a></span>|<span class="type"><a href="language.types.singleton.php" class="type false">false</a></span></span></div>

  <p class="para rdfs-comment">
   A função <span class="function"><strong>stream_select()</strong></span> aceita arrays de fluxos e
   espera por alteração em seus estados. Sua operação é equivalente à da
   função <span class="function"><a href="function.socket-select.php" class="function">socket_select()</a></span> exceto por atuar em fluxos.
  </p>
 </div>


 <div class="refsect1 parameters" id="refsect1-function.stream-select-parameters">
  <h3 class="title">Parâmetros</h3>
  <p class="para">
   <dl>
    
     <dt><code class="parameter">read</code></dt>
     <dd>
      <p class="para">
       Os fluxos listados no array <code class="parameter">read</code> serão observados para
       ver se caracteres se tornem disponíveis para leitura (mais precisamente, para ver se
       uma leitura não irá bloquear - em particular, um recurso de fluxo já se encontra pronto no
       final do arquivo, neste caso a função <span class="function"><a href="function.fread.php" class="function">fread()</a></span> irá retornar uma string
       com comprimento zero).
      </p>
     </dd>
    
    
     <dt><code class="parameter">write</code></dt>
     <dd>
      <p class="para">
       Os fluxos listados no array <code class="parameter">write</code> serão
       observados para ver se uma escrita não irá bloquear.
      </p>
     </dd>
    
    
     <dt><code class="parameter">except</code></dt>
     <dd>
      <p class="para">
       Os fluxos listados no array <code class="parameter">except</code> serão observados
       para chegada de dados excepcional (&quot;fora-de-banda&quot;) de alta prioridade.
      </p>
      <blockquote class="note"><p><strong class="note">Nota</strong>: 
       <p class="para">
        Quando <span class="function"><strong>stream_select()</strong></span> retorna, os arrays
        <code class="parameter">read</code>, <code class="parameter">write</code> e
        <code class="parameter">except</code> são modificados para indicar qual(is) recurso(s)
        de fluxo realmente tiveram o estado alterado.
        As chaves originais dos <span class="type"><a href="language.types.array.php" class="type array">array</a></span>s são preservadas.
       </p>
      </p></blockquote>
     </dd>
    
    
     <dt><code class="parameter">seconds</code></dt>
     <dd>
      <p class="para">
       Os parâmetros <code class="parameter">seconds</code> e <code class="parameter">microseconds</code>
       formam juntos o parâmetro <em>limite de tempo</em>,
       <code class="parameter">seconds</code> especifica o número de segundos e
       <code class="parameter">microseconds</code> o número de microssegundos.
       O parâmetro <code class="parameter">timeout</code> é um limite do tempo
       que <span class="function"><strong>stream_select()</strong></span> esperará antes de retornar.
       Se <code class="parameter">seconds</code> for igual a <code class="literal">0</code> e
       <code class="parameter">microseconds</code> for igual a <code class="literal">0</code> ou <strong><code><a href="reserved.constants.php#constant.null">null</a></code></strong>,
       <span class="function"><strong>stream_select()</strong></span> não esperará por dados - em vez disso retornará imediatamente,
       indicando o estado atual dos fluxos.
      </p>
      <p class="para">
       Se <code class="parameter">seconds</code> for <strong><code><a href="reserved.constants.php#constant.null">null</a></code></strong> <span class="function"><strong>stream_select()</strong></span>
       pode bloquear indefinidamente, retornando somente quando um evento em algum dos
       fluxos observados ocorrer (ou se um sinal interromper a chamada de sistema).
      </p>
      <div class="warning"><strong class="warning">Aviso</strong>
       <p class="para">
        Usando um valor de <code class="literal">0</code> no limite de tempo permite que
        se faça pesquisa instantânea dos estados dos fluxos, entretanto, NÃO é
        recomendado usar um limite de <code class="literal">0</code> em um loop pois poderá
        causar um consumo excessivo de tempo de CPU.
       </p>
       <p class="para">
        É muito melhor especificar um limite de tempo de alguns segundos, embora
        caso seja necessário ficar verificando e executando outro código concorrentemente, usar
        um limite de pelo menos <code class="literal">200000</code> microssegundos ajudará
        a reduzir o consumo de CPU do seu script.
       </p>
       <p class="para">
        Lembre-se que o valor de limite de tempo é o tempo máximo que irá decorrer;
        <span class="function"><strong>stream_select()</strong></span> irá retornar tão logo os fluxos
        requisitados estiverem prontos para uso.
       </p>
      </div>
     </dd>
    
    
     <dt><code class="parameter">microseconds</code></dt>
     <dd>
      <p class="para">
       Veja descrição de <code class="parameter">seconds</code>.
      </p>
     </dd>
    
   </dl>
  </p>
 </div>


 <div class="refsect1 returnvalues" id="refsect1-function.stream-select-returnvalues">
  <h3 class="title">Valor Retornado</h3>
  <p class="para">
   Em caso de sucesso, <span class="function"><strong>stream_select()</strong></span> retorna o número de
   recursos de fluxo contidos nos arrays modificados, o que pode ser zero se
   o limite de tempo for alcançado antes que alguma coisa interessante aconteça. Em caso de erro, <strong><code><a href="reserved.constants.php#constant.false">false</a></code></strong>
   é retornado e um aviso é emitido (isto pode acontecer se a chamada ao sistema for
   interrompida por algum sinal).
  </p>
 </div>


 <div class="refsect1 changelog" id="refsect1-function.stream-select-changelog">
  <h3 class="title">Registro de Alterações</h3>
  <table class="doctable informaltable">
   
    <thead>
     <tr>
      <th>Versão</th>
      <th>Descrição</th>
     </tr>

    </thead>

    <tbody class="tbody">
     <tr>
      <td>8.1.0</td>
      <td>
       <code class="parameter">microseconds</code> agora pode ser nulo.
      </td>
     </tr>

    </tbody>
   
  </table>

 </div>


 <div class="refsect1 examples" id="refsect1-function.stream-select-examples">
  <h3 class="title">Exemplos</h3>
  <p class="para">
   <div class="example" id="example-1">
    <p><strong>Exemplo #1 Exemplo de <span class="function"><strong>stream_select()</strong></span></strong></p>
    <div class="example-contents"><p>
     Este exemplo verifica se dados chegaram para leitura em
     <code class="parameter">$stream1</code> ou <code class="parameter">$stream2</code>.
     Como o valor de limite de tempo é <code class="literal">0</code> a função retornará
     imediatamente:
    </p></div>
    <div class="example-contents">
<div class="phpcode"><code><span style="color: #000000"><span style="color: #0000BB">&lt;?php<br /></span><span style="color: #FF8000">/* Prepara o array de leitura */<br /></span><span style="color: #0000BB">$read   </span><span style="color: #007700">= array(</span><span style="color: #0000BB">$stream1</span><span style="color: #007700">, </span><span style="color: #0000BB">$stream2</span><span style="color: #007700">);<br /></span><span style="color: #0000BB">$write  </span><span style="color: #007700">= </span><span style="color: #0000BB">NULL</span><span style="color: #007700">;<br /></span><span style="color: #0000BB">$except </span><span style="color: #007700">= </span><span style="color: #0000BB">NULL</span><span style="color: #007700">;<br />if (</span><span style="color: #0000BB">false </span><span style="color: #007700">=== (</span><span style="color: #0000BB">$num_changed_streams </span><span style="color: #007700">= </span><span style="color: #0000BB">stream_select</span><span style="color: #007700">(</span><span style="color: #0000BB">$read</span><span style="color: #007700">, </span><span style="color: #0000BB">$write</span><span style="color: #007700">, </span><span style="color: #0000BB">$except</span><span style="color: #007700">, </span><span style="color: #0000BB">0</span><span style="color: #007700">))) {<br />    </span><span style="color: #FF8000">/* Lidando com erros */<br /></span><span style="color: #007700">} elseif (</span><span style="color: #0000BB">$num_changed_streams </span><span style="color: #007700">&gt; </span><span style="color: #0000BB">0</span><span style="color: #007700">) {<br />    </span><span style="color: #FF8000">/* Pelo menos em um dos fluxos algo interessante ocorreu */<br /></span><span style="color: #007700">}<br /></span><span style="color: #0000BB">?&gt;</span></span></code></div>
    </div>

   </div>
  </p>
 </div>


 <div class="refsect1 notes" id="refsect1-function.stream-select-notes">
  <h3 class="title">Notas</h3>
  <blockquote class="note"><p><strong class="note">Nota</strong>: 
   <p class="para">
    Devido a uma limitação no motor Zend atual, não é possível passar um
    modificador de constante como <strong><code><a href="reserved.constants.php#constant.null">null</a></code></strong> diretamente como um parâmetro para uma função
    que espera que o parâmetro seja passado por referência. Em vez disso, use uma
    variável temporária ou uma expressão com o membro mais a esquerda sendo uma
    variável temporária:
    <div class="example-contents">
<div class="phpcode"><code><span style="color: #000000"><span style="color: #0000BB">&lt;?php<br />$e </span><span style="color: #007700">= </span><span style="color: #0000BB">NULL</span><span style="color: #007700">;<br /></span><span style="color: #0000BB">stream_select</span><span style="color: #007700">(</span><span style="color: #0000BB">$r</span><span style="color: #007700">, </span><span style="color: #0000BB">$w</span><span style="color: #007700">, </span><span style="color: #0000BB">$e</span><span style="color: #007700">, </span><span style="color: #0000BB">0</span><span style="color: #007700">);<br /></span><span style="color: #0000BB">?&gt;</span></span></code></div>
   </div>

   </p>
  </p></blockquote>
  <blockquote class="note"><p><strong class="note">Nota</strong>: 
   <p class="para">
   Certifique-se de usar o operador <code class="literal">===</code> na verificação de
   erro. Como a função <span class="function"><strong>stream_select()</strong></span> pode retornar 0, a
   comparação com <code class="literal">==</code> pode ser interpretada como <strong><code><a href="reserved.constants.php#constant.true">true</a></code></strong>:
   <div class="example-contents">
<div class="phpcode"><code><span style="color: #000000"><span style="color: #0000BB">&lt;?php<br />$e </span><span style="color: #007700">= </span><span style="color: #0000BB">NULL</span><span style="color: #007700">;<br />if (</span><span style="color: #0000BB">false </span><span style="color: #007700">=== </span><span style="color: #0000BB">stream_select</span><span style="color: #007700">(</span><span style="color: #0000BB">$r</span><span style="color: #007700">, </span><span style="color: #0000BB">$w</span><span style="color: #007700">, </span><span style="color: #0000BB">$e</span><span style="color: #007700">, </span><span style="color: #0000BB">0</span><span style="color: #007700">)) {<br />    echo </span><span style="color: #DD0000">"stream_select() falhou\n"</span><span style="color: #007700">;<br />}<br /></span><span style="color: #0000BB">?&gt;</span></span></code></div>
   </div>

   </p>
  </p></blockquote>
  <blockquote class="note"><p><strong class="note">Nota</strong>: 
   <p class="para">
    Se for realizada leitura/escrita em um fluxo retornado nos arrays, esteja ciente que
    não necessariamente serão lidos/escritos todos os dados
    solicitados. Esteja preparado para a possibilidade de se ler/escrever apenas
    um único byte.
   </p>
  </p></blockquote>
  <blockquote class="note"><p><strong class="note">Nota</strong>: 
   <p class="para">
    Alguns fluxos (como <code class="literal">zlib</code>) não podem ser selecionados por esta
    função.
   </p>
  </p></blockquote>
  <blockquote class="note"><p><strong class="note">Nota</strong>: 
   <strong>Compatibilidade com Windows</strong><br />
   <p class="para">
    O uso de <span class="function"><strong>stream_select()</strong></span> em
    descritores de arquivos retornados por <span class="function"><a href="function.proc-open.php" class="function">proc_open()</a></span> irão falhar
    e retornar <strong><code><a href="reserved.constants.php#constant.false">false</a></code></strong> no Windows.
   </p>
   <p class="para">
    <strong><code><a href="reserved.constants.php#constant.stdin">STDIN</a></code></strong> de um console muda de estado assim que <em>qualquer</em>
    evento de entrada estiver disponível, mas a leitura do fluxo ainda poderá bloquear.
   </p>
  </p></blockquote>
 </div>


 <div class="refsect1 seealso" id="refsect1-function.stream-select-seealso">
  <h3 class="title">Veja Também</h3>
  <ul class="simplelist">
   <li><span class="function"><a href="function.stream-set-blocking.php" class="function" rel="rdfs-seeAlso">stream_set_blocking()</a> - Definir modo de bloqueio/n&atilde;o-bloqueio em um fluxo</span></li>
  </ul>
 </div>

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