Kapitel 22. Zend_Memory

Inhaltsverzeichnis

22.1. Übersicht
22.1.1. Einführung
22.1.2. Theorie der Verwendung
22.2. Memory Manager
22.2.1. Erstellen eines Memory Manager
22.2.2. Memory Objekte verwalten
22.2.3. Memory Manager Einstellungen
22.3. Memory Objekte
22.3.1. Verschiebbar
22.3.2. Gesperrt
22.3.3. Memory Container 'value' Eigenschaft.
22.3.4. Memory Container Interface

22.1. Übersicht

22.1.1. Einführung

Die Zend_Memory Komponente ist dafür gedacht Daten in Systemen mit limitiertem Speicher zu Verwalten.

Memory Objekte (Memory Container) werden durch den Memory Manager bei Anfrage erzeugt und transparent geswappt/geladen wenn dies notwendig wird.

Wenn, zum Beispiel, ein gemanagtes Objekt erzeugt oder geladen wird, das den gesamten Speicherverbrauch überschreiten würde, der vorher definiert wurde, werden einige gemanagte Objekte in den Cache Speicher ausserhalb des Speichers kopiert. Auf diesen Weg wird der Gesamtspeicher der von den gemanagten Objekten verwendet wird nicht das benötigte Limit überschreiten.

Der Memory Manager verwendet Zend_Cache backends als Speicheranbieter.

Beispiel 22.1. Verwenden der Zend_Memory Komponente

Zend_Memory::factory() instantiiert das Speichermanager Objekt mit den definierten Backend Optionen.

<?php

require_once 'Zend/Memory.php';

$backendOptions = array(
    'cacheDir' => './tmp/' // Verzeichnis in welches die getauschten Speicherblöcke geschrieben werden
);

$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. Theorie der Verwendung

Die Zend_Memory Konponente arbeitet mit den folgenden Konzepten:

  • Memory Manager

  • Memory Container

  • Verschlüsseltes Memory Objekt

  • Verschiebbares Memory Objekt

22.1.2.1. Memory Manager

Der Memory Manager erzeugt Memory Objekte (gesperrt oder verschiebbar) durch Anfrage der Anwendung des Benutzers und gibt diese in einem Memory Container Objekt zurück.

22.1.2.2. Memory Container

Der Memory Container hat einen virtuellen oder aktuellen Wert, Attribut oder Zeichenketten Typ. Dieses Attribut enthält Datenwerte die bei der Erstellung des Memory Objektes definiert werden.

Es kann mit Wert Attributen wie auch mit Objekt Eigenschaften gearbeitet werden.

<?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);

?>

[Anmerkung] Anmerkung

Wenn eine PHP Version vor 5.2 verwendet wird, sollte stattdessen die getRef() Methode verwendet werden statt direkt auf die Wert Eigenschaften zuzugreifen.

:

22.1.2.3. Verschlüsselter Memory

Verschlüsselte Speicher Objekte werden immer im Speicher gespeichert. Daten welche im verschlüsselten Speicher gespeichert sind, werden niemals in das Cache Backend getauscht.

22.1.2.4. Verschiebbarer Memory

Verschiebbare Memory Objekte werden transparent geswappt und geladen von und in das Cache Backend durch Zend_Memory wenn das notwendig wird.

Der Memory Manager swappt keine Objekte die eine kleinere Größe als das definierte Minimum besitzen, und zwar aus Gründen der Geschwindigkeit. Siehe Abschnitt 22.2.3.2, „MinSize“ für mehr Details.