(PECL quickhash >= Unknown)
QuickHashIntStringHash::loadFromFile — Cette méthode d'usine crée un hachage à partir d'un fichier
$filename
, int $size
= 0, int $options
= 0): QuickHashIntStringHash
Cette méthode d'usine crée un nouveau hachage à partir d'un fichier de définition sur le disque. Le
format du fichier consiste en une signature 'QH\0x12\0'
, le nombre d'éléments en tant
qu'entier signé 32 bits en Endianness du système, un entier non signé 32 bits
contenant le nombre de données d'éléments à suivre en caractères. Ces données
d'éléments contiennent toutes les chaînes. Après l'en-tête et les chaînes, les
éléments suivent par paires de deux entiers non signés 32 bits où le premier
est la clé, et le second l'index dans la chaîne de données d'éléments.
Un exemple pourrait être :
Exemple #1 Format de fichier QuickHash IntString
00000000 51 48 12 00 02 00 00 00 09 00 00 00 4f 4e 45 00 |QH..........ONE.| 00000010 4e 49 4e 45 00 01 00 00 00 00 00 00 00 03 00 00 |NINE............| 00000020 00 04 00 00 00 |.....| 00000025
Exemple #2 Format de fichier QuickHash IntString
header signature ('QH'; key type: 1; value type: 2; filler: \0x00) 00000000 51 48 12 00 number of elements: 00000004 02 00 00 00 length of string values (9 characters): 00000008 09 00 00 00 string values: 0000000C 4f 4e 45 00 4e 49 4e 45 00 data string: 00000015 01 00 00 00 00 00 00 00 03 00 00 00 04 00 00 00 key/value 1 (key = 1, string index = 0 ("ONE")): 01 00 00 00 00 00 00 00 key/value 2 (key = 3, string index = 4 ("NINE")): 03 00 00 00 04 00 00 00
filename
Le nom du fichier à partir duquel lire le hachage.
size
La quantité de listes de seaux à configurer. Le nombre que vous passez sera
automatiquement arrondi à la puissance de deux suivante. Il est également
automatiquement limité de 4
à 4194304
.
options
Les mêmes options que le constructeur de la classe ; sauf que l'option
size est ignorée. Elle est automatiquement calculée pour être la même que
le nombre d'entrées dans le hachage, arrondie à la puissance de deux la plus proche
avec une limite maximale de 4194304
.
Renvoie un nouveau QuickHashIntStringHash.
Exemple #3 Exemple de QuickHashIntStringHash::loadFromFile()
<?php
$file = dirname( __FILE__ ) . "/simple.string.hash";
$hash = QuickHashIntStringHash::loadFromFile(
$file,
QuickHashIntStringHash::DO_NOT_USE_ZEND_ALLOC
);
foreach( range( 0, 0x0f ) as $key )
{
printf( "Key %3d (%2x) is %s\n",
$key, $key,
$hash->exists( $key ) ? 'set' : 'unset'
);
}
?>
Résultat de l'exemple ci-dessus est similaire à :
Key 0 ( 0) is unset Key 1 ( 1) is set Key 2 ( 2) is set Key 3 ( 3) is set Key 4 ( 4) is unset Key 5 ( 5) is set Key 6 ( 6) is unset Key 7 ( 7) is set Key 8 ( 8) is unset Key 9 ( 9) is unset Key 10 ( a) is unset Key 11 ( b) is set Key 12 ( c) is unset Key 13 ( d) is set Key 14 ( e) is unset Key 15 ( f) is unset