Chapitre 22. Zend_Memory

Table des matières

22.1. Présentation
22.1.1. Introduction
22.1.2. Point de vue théorique
22.2. Manager de mémoire
22.2.1. Créer un manager de mémoire
22.2.2. Manager les objets mémoire
22.2.3. Régler le manager de mémoire
22.3. Objet mémoire
22.3.1. Mobile
22.3.2. Vérouillé
22.3.3. Propriété 'value' du manager de mémoire
22.3.4. Interface du conteneur de mémoire

22.1. Présentation

22.1.1. Introduction

Le composant Zend_Memory est destiné à gérer des données dans un environnement où la mémoire est limitée.

Les objets mémoire (conteneurs de mémoire) sont produits par le manager de mémoire sur demande et mis en cache/chargés d'une manière transparente quand c'est nécessaire.

Par exemple, si la création ou le chargement d'un objet entraîne une utilisation de mémoire totale excèdant la limite que vous spécifiez, certains objets gérés sont copiés en cache à l'extérieur de la mémoire. De cette façon, la mémoire totale utilisée par les objets gérés n'excède pas la limite que vous devez mettre en application.

Le manager de mémoire utilise les backends Zend_Cache comme fournisseurs de stockage.

Exemple 22.1. Utiliser le composant Zend_Memory

Zend_Memory::factory() instancie l'objet de management de la mémoire avec les options spécifiques du backend.

<?php
require_once 'Zend/Memory.php';

$backendOptions = array(
    'cacheDir' => './tmp/' // Dossier où les blocks de mémoire peuvent être stockés
);

$memoryManager = Zend_Memory::factory('File', $backendOptions);

$loadedFiles = array();

for ($count = 0; $count < 10000; $count++) {
    $f = fopen($fileNames[$count], 'rb');
    $data = fread($f, filesize($fileNames[$count]));
    $fclose($f);

    $loadedFiles[] = $memoryManager->create($data);
}

echo $loadedFiles[$index1]->value;

$loadedFiles[$index2]->value = $newValue;

$loadedFiles[$index3]->value[$charIndex] = '_';
?>

22.1.2. Point de vue théorique

Zend_Memory travaille avec les concepts suivants :

  • Manager de mémoire

  • Conteneur de mémoire

  • Objet de mémoire vérrouillé

  • Objet de mémoire mobile

22.1.2.1. Manager de mémoire

Le manager de mémoire produit des objets de mémoire (verrouillé ou mobile) sur demande de l'utilisateur et les retourne encapsulé dans un objet conteneur de mémoire.

22.1.2.2. Conteneur de mémoire

Le conteneur de mémoire(souvenir) a un attribut value virtuel ou réel de type chaîne de caractères. Cet attribut contient la valeur de donnée indiquée au moment de la création de l'objet mémoire.

Vous pouvez exploiter cet attribut value comme une propriété d'objet :

<?php

$memObject = $memoryManager->create($data);

echo $memObject->value;

$memObject->value = $newValue;

$memObject->value[$index] = '_';

echo ord($memObject->value[$index1]);

$memObject->value = substr($memObject->value, $start, $length);
?>

[Note] Note

Si vous utilisez une version de PHP inférieure à 5.2, utilisez la méthode getRef() au lieu d'accéder directement à la valeur de la propriété.

22.1.2.3. Objet de mémoire vérrouillé

Les objets de mémoire vérrouillés sont toujours stockés dans la mémoire. Les données stockées dans la mémoire verrouillée ne sont jamais mis en cache.

22.1.2.4. Objet de mémoire mobile

Les objets de mémoire mobiles sont mis en cache et chargés de manière transparente de/vers le cache par Zend_Memory si c'est nécessaire.

Le manager de mémoire ne met pas en cache des objets ayant une taille plus pettite que le minimum spécifié dans un soucis de performances. Voir Section 22.2.3.2, « MinSize (taille minimum) » pour plus de détails.