<?php
include_once $_SERVER['DOCUMENT_ROOT'] . '/include/shared-manual.inc';
$TOC = array();
$TOC_DEPRECATED = array();
$PARENTS = array();
include_once dirname(__FILE__) ."/toc/class.quickhashstringinthash.inc";
$setup = array (
  'home' => 
  array (
    0 => 'index.php',
    1 => 'PHP Manual',
  ),
  'head' => 
  array (
    0 => 'UTF-8',
    1 => 'es',
  ),
  'this' => 
  array (
    0 => 'quickhashstringinthash.loadfromfile.php',
    1 => 'QuickHashStringIntHash::loadFromFile',
    2 => 'Este m&eacute;todo de f&aacute;brica crea un hash a partir de un fichero',
  ),
  'up' => 
  array (
    0 => 'class.quickhashstringinthash.php',
    1 => 'QuickHashStringIntHash',
  ),
  'prev' => 
  array (
    0 => 'quickhashstringinthash.getsize.php',
    1 => 'QuickHashStringIntHash::getSize',
  ),
  'next' => 
  array (
    0 => 'quickhashstringinthash.loadfromstring.php',
    1 => 'QuickHashStringIntHash::loadFromString',
  ),
  'alternatives' => 
  array (
  ),
  'source' => 
  array (
    'lang' => 'es',
    'path' => 'reference/quickhash/quickhashstringinthash/loadfromfile.xml',
  ),
  'history' => 
  array (
  ),
);
$setup["toc"] = $TOC;
$setup["toc_deprecated"] = $TOC_DEPRECATED;
$setup["parents"] = $PARENTS;
manual_setup($setup);

contributors($setup);

?>
<div id="quickhashstringinthash.loadfromfile" class="refentry">
 <div class="refnamediv">
  <h1 class="refname">QuickHashStringIntHash::loadFromFile</h1>
  <p class="verinfo">(No version information available, might only be in Git)</p><p class="refpurpose"><span class="refname">QuickHashStringIntHash::loadFromFile</span> &mdash; <span class="dc-title">Este método de fábrica crea un hash a partir de un fichero</span></p>

 </div>

 <div class="refsect1 description" id="refsect1-quickhashstringinthash.loadfromfile-description">
  <h3 class="title">Descripción</h3>
  <div class="methodsynopsis dc-description">
   <span class="modifier">public</span> <span class="modifier">static</span> <span class="methodname"><strong>QuickHashStringIntHash::loadFromFile</strong></span>(<span class="methodparam"><span class="type"><a href="language.types.string.php" class="type string">string</a></span> <code class="parameter">$filename</code></span>, <span class="methodparam"><span class="type"><a href="language.types.integer.php" class="type int">int</a></span> <code class="parameter">$size</code><span class="initializer"> = 0</span></span>, <span class="methodparam"><span class="type"><a href="language.types.integer.php" class="type int">int</a></span> <code class="parameter">$options</code><span class="initializer"> = 0</span></span>): <span class="type"><a href="class.quickhashstringinthash.php" class="type QuickHashStringIntHash">QuickHashStringIntHash</a></span></div>

  <p class="simpara">
   Este método de fábrica crea un nuevo hash a partir de un fichero de definición en el disco. El
   formato del fichero se compone de una firma <code class="literal">&#039;QH\0x21\0&#039;</code>, del número de elementos como
   entero signado de 32 bits en Endianness del sistema, un entero no signado de 32 bits
   conteniendo el número de datos de elementos a seguir en caracteres. Estos datos
   de elementos contienen todas las strings. Sigue otro entero signado de 32 bits
   conteniendo el número de listas de cubos. Después del encabezado y las strings,
   los elementos siguen. Están ordenados por lista de cubos de manera que las claves no
   deben ser hasheadas para restaurar el hash. Para cada lista de cubos, la siguiente información es almacenada (todas en enteros de 32 bits): el índice de la lista de cubos,
   el número de elementos en esta lista, y luego por parejas de dos
   enteros no signados de 32 bits los elementos, donde el primero es el índice
   en la lista de strings conteniendo las claves, y el segundo el valor. Un
   ejemplo podría ser:
  </p>
  <div class="example" id="example-1">
   <p><strong>Ejemplo #1 Formato de fichero QuickHash StringIntHash</strong></p>
   <div class="example-contents screen"><div class="descriptioncode"><pre class="descriptioncode">00000000  51 48 21 00 02 00 00 00  09 00 00 00 40 00 00 00  |QH!.........@...|
00000010  4f 4e 45 00 4e 49 4e 45  00 07 00 00 00 01 00 00  |ONE.NINE........|
00000020  00 00 00 00 00 01 00 00  00 2f 00 00 00 01 00 00  |........./......|
00000030  00 04 00 00 00 03 00 00  00                       |.........|
00000039</pre>
</div></div>
  </div>
  <div class="example" id="example-2">
   <p><strong>Ejemplo #2 Formato de fichero QuickHash IntHash</strong></p>
   <div class="example-contents screen"><div class="descriptioncode"><pre class="descriptioncode">firma del encabezado (&#039;QH&#039;; tipo de clave: 2; tipo de valor: 1; relleno: \0x00)
00000000  51 48 21 00

número de elementos:
00000004  02 00 00 00

longitud de valores de string (9 caracteres):
00000008  09 00 00 00

número de listas de cubos de hash (esto se configura para hashes como argumento al
constructor normalmente, 64 en este caso):
0000000C  40 00 00 00

valores de string:
00000010  4f 4e 45 00 4e 49 4e 45  00

listas de cubos:
  lista de cubos 1 (con clave 7, y 1 elemento):
    encabezado:
    07 00 00 00 01 00 00 00
    elementos (índice de clave: 0 (&#039;ONE&#039;), valor = 0):
    00 00 00 00 01 00 00 00
  lista de cubos 2 (con clave 0x2f, y 1 elemento):
    encabezado:
    2f 00 00 00 01 00 00 00
    elementos (índice de clave: 4 (&#039;NINE&#039;), valor = 3):
    04 00 00 00 03 00 00 00</pre>
</div></div>
  </div>
 </div>


 <div class="refsect1 parameters" id="refsect1-quickhashstringinthash.loadfromfile-parameters">
  <h3 class="title">Parámetros</h3>
  <dl>
   
    <dt><code class="parameter">filename</code></dt>
    <dd>
     <span class="simpara">
      El nombre del fichero desde el cual leer el hash.
     </span>
    </dd>
   
   
    <dt><code class="parameter">size</code></dt>
    <dd>
     <span class="simpara">
      El número de listas de cubos a configurar. El número que se pasa será
      automáticamente redondeado a la siguiente potencia de dos. También es
      automáticamente limitado de <code class="literal">4</code> a <code class="literal">4194304</code>.
     </span>
    </dd>
   
   
    <dt><code class="parameter">options</code></dt>
    <dd>
     <span class="simpara">
      Las mismas opciones que el constructor de la clase; excepto que la opción
      size es ignorada. Se lee desde el formato de fichero (a diferencia de las
      clases <span class="classname"><a href="class.quickhashinthash.php" class="classname">QuickHashIntHash</a></span> y <span class="classname"><a href="class.quickhashintstringhash.php" class="classname">QuickHashIntStringHash</a></span>, donde se
      calcula automáticamente a partir del número de entradas en el hash.)
     </span>
    </dd>
   
  </dl>
 </div>


 <div class="refsect1 returnvalues" id="refsect1-quickhashstringinthash.loadfromfile-returnvalues">
  <h3 class="title">Valores devueltos</h3>
  <p class="simpara">
   Devuelve un nuevo <span class="classname"><a href="class.quickhashstringinthash.php" class="classname">QuickHashStringIntHash</a></span>.
  </p>
 </div>


 <div class="refsect1 examples" id="refsect1-quickhashstringinthash.loadfromfile-examples">
  <h3 class="title">Ejemplos</h3>
  <div class="example" id="example-3">
   <p><strong>Ejemplo #3 Ejemplo de <span class="function"><strong>QuickHashStringIntHash::loadFromFile()</strong></span></strong></p>
   <div class="example-contents">
<div class="phpcode"><code><span style="color: #000000"><span style="color: #0000BB">&lt;?php<br />$file </span><span style="color: #007700">= </span><span style="color: #0000BB">dirname</span><span style="color: #007700">( </span><span style="color: #0000BB">__FILE__ </span><span style="color: #007700">) . </span><span style="color: #DD0000">"/simple.hash.string"</span><span style="color: #007700">;<br /></span><span style="color: #0000BB">$hash </span><span style="color: #007700">= </span><span style="color: #0000BB">QuickHashStringIntHash</span><span style="color: #007700">::</span><span style="color: #0000BB">loadFromFile</span><span style="color: #007700">(<br />    </span><span style="color: #0000BB">$file</span><span style="color: #007700">,<br />    </span><span style="color: #0000BB">QuickHashStringIntHash</span><span style="color: #007700">::</span><span style="color: #0000BB">DO_NOT_USE_ZEND_ALLOC<br /></span><span style="color: #007700">);<br />foreach( </span><span style="color: #0000BB">range</span><span style="color: #007700">( </span><span style="color: #0000BB">0</span><span style="color: #007700">, </span><span style="color: #0000BB">0x0f </span><span style="color: #007700">) as </span><span style="color: #0000BB">$key </span><span style="color: #007700">)<br />{<br />    </span><span style="color: #0000BB">$i </span><span style="color: #007700">= </span><span style="color: #0000BB">48712 </span><span style="color: #007700">+ </span><span style="color: #0000BB">$key </span><span style="color: #007700">* </span><span style="color: #0000BB">1631</span><span style="color: #007700">;<br />    </span><span style="color: #0000BB">$k </span><span style="color: #007700">= </span><span style="color: #0000BB">base_convert</span><span style="color: #007700">( </span><span style="color: #0000BB">$i</span><span style="color: #007700">, </span><span style="color: #0000BB">10</span><span style="color: #007700">, </span><span style="color: #0000BB">36 </span><span style="color: #007700">);<br />    echo </span><span style="color: #0000BB">$k</span><span style="color: #007700">, </span><span style="color: #DD0000">' =&gt; '</span><span style="color: #007700">, </span><span style="color: #0000BB">$hash</span><span style="color: #007700">-&gt;</span><span style="color: #0000BB">get</span><span style="color: #007700">( </span><span style="color: #0000BB">$k </span><span style="color: #007700">), </span><span style="color: #DD0000">"\n"</span><span style="color: #007700">;<br />}<br /></span><span style="color: #0000BB">?&gt;</span></span></code></div>
   </div>

   <div class="example-contents"><p>Resultado del ejemplo anterior es similar a:</p></div>
   <div class="example-contents screen">
<div class="examplescode"><pre class="examplescode">11l4 =&gt; 48712
12uf =&gt; 50343
143q =&gt; 51974
15d1 =&gt; 53605
16mc =&gt; 55236
17vn =&gt; 56867
194y =&gt; 58498
1ae9 =&gt; 60129
1bnk =&gt; 61760
1cwv =&gt; 63391
1e66 =&gt; 65022
1ffh =&gt; 66653
1gos =&gt; 68284
1hy3 =&gt; 69915
1j7e =&gt; 71546
1kgp =&gt; 73177</pre>
</div>
   </div>
  </div>
 </div>


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