PHPerKaigi 2025

La classe QuickHashIntHash

(PECL quickhash >= Unknown)

Introduction

Cette classe enveloppe un hachage contenant des nombres entiers, où les valeurs sont également des nombres entiers. Les hachages sont également disponibles en tant qu'implémentation de l'interface ArrayAccess.

Les hachages peuvent être itérés avec foreach car l'interface Iterator est également implémentée. L'ordre dans lequel les éléments sont retournés n'est pas garanti.

Synopsis de la classe

class QuickHashIntHash {
/* Constantes */
const int CHECK_FOR_DUPES = 1;
const int HASHER_NO_HASH = 256;
const int HASHER_JENKINS1 = 512;
const int HASHER_JENKINS2 = 1024;
/* Méthodes */
public add(int $key, int $value = ?): bool
public __construct(int $size, int $options = ?)
public delete(int $key): bool
public exists(int $key): bool
public get(int $key): int
public getSize(): int
public static loadFromFile(string $filename, int $options = ?): QuickHashIntHash
public static loadFromString(string $contents, int $options = ?): QuickHashIntHash
public saveToFile(string $filename): void
public set(int $key, int $value): bool
public update(int $key, int $value): bool
}

Constantes pré-définies

QuickHashIntHash::CHECK_FOR_DUPES

Si activé, l'ajout d'éléments dupliqués à un hachage (via QuickHashIntHash::add() ou QuickHashIntHash::loadFromFile()) entraînera la suppression de ces éléments du hachage. Cela prendra plus de temps, donc n'utilisez-le que si c'est nécessaire.

QuickHashIntHash::DO_NOT_USE_ZEND_ALLOC

Désactive l'utilisation du gestionnaire de mémoire interne de PHP pour les structures de jeu internes. Avec cette option activée, les allocations internes ne compteront pas dans les paramètres memory_limit.

QuickHashIntHash::HASHER_NO_HASH

Sélectionne de ne pas utiliser de fonction de hachage, mais simplement utiliser un modulo pour trouver l'index de la liste de seaux. Cela n'est pas plus rapide que le hachage normal, et donne plus de collisions.

QuickHashIntHash::HASHER_JENKINS1

Ceci est la fonction de hachage par défaut pour transformer les hachages entiers en index de liste de seaux.

QuickHashIntHash::HASHER_JENKINS2

Selectionne un algorithme de hachage de variante.

Sommaire

add a note

User Contributed Notes

There are no user contributed notes for this page.
To Top