Zend_Memory-MemoryManager.xml 7.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- EN-Revision: 24249 -->
  3. <!-- Reviewed: no -->
  4. <sect1 id="zend.memory.memory-manager">
  5. <title>Memory Manager</title>
  6. <sect2 id="zend.memory.memory-manager.creation">
  7. <title>Erstellen eines Memory Manager</title>
  8. <para>
  9. Ein neuer Memory Manager (<classname>Zend_Memory_Manager</classname> object)
  10. kann erstellt werden durch Verwendung der
  11. <methodname>Zend_Memory::factory($backendName [, $backendOprions])</methodname>
  12. Methode.
  13. </para>
  14. <para>
  15. Das erste Argument <varname>$backendName</varname> ist eine Zeichenkette die
  16. eine der Backend Implementationen benennt welche durch <classname>Zend_Cache</classname>
  17. unterstützt werden.
  18. </para>
  19. <para>
  20. Das zweite Argument <varname>$backendOptions</varname> ist ein optionales
  21. Array für die Optionen des Backends.
  22. </para>
  23. <programlisting language="php"><![CDATA[
  24. $backendOptions = array(
  25. // Verzeichnis in dem die geswappten Memory Blöcke abgelegt werden
  26. 'cache_dir' => './tmp/'
  27. );
  28. $memoryManager = Zend_Memory::factory('File', $backendOptions);
  29. ]]></programlisting>
  30. <para>
  31. <classname>Zend_Memory</classname> verwendet <link
  32. linkend="zend.cache.backends"><classname>Zend_Cache Backends</classname></link>
  33. als Speicheranbieter.
  34. </para>
  35. <para>
  36. Der spezielle Name 'None' kann als Backend Name verwendet werden,
  37. zusätzlich zu den Standard <classname>Zend_Cache</classname> Backends.
  38. </para>
  39. <programlisting language="php"><![CDATA[
  40. $memoryManager = Zend_Memory::factory('None');
  41. ]]></programlisting>
  42. <para>
  43. Wenn 'None' als Backend Name verwendet wird, dann tauscht der
  44. Memory Manager niemals die Memory Blöcke. Das ist nützlich wenn man weiß das
  45. Speicher nicht limitiert ist oder die Gesamtgröße der Objekte nie das
  46. Speicherlimit erreicht.
  47. </para>
  48. <para>
  49. Das 'None' Backend benötigt keine Definition von Optionen.
  50. </para>
  51. </sect2>
  52. <sect2 id="zend.memory.memory-manager.objects-management">
  53. <title>Memory Objekte verwalten</title>
  54. <para>
  55. Diese Sektion beschreibt die Erstellung und Vernichtung von Objekten im
  56. Memory Manager, und die Einstellungen um das Verhalten des Memory
  57. Managers zu kontrollieren.
  58. </para>
  59. <sect3 id="zend.memory.memory-manager.objects-management.movable">
  60. <title>Erstellung verschiebbarer Objekte</title>
  61. <para>
  62. Verschiebbare Objekte (Objekte, welche verschoben werden können)
  63. können erstellt werden mit Hilfe der
  64. <methodname>Zend_Memory_Manager::create([$data])</methodname> Methode:
  65. </para>
  66. <programlisting language="php"><![CDATA[
  67. $memObject = $memoryManager->create($data);
  68. ]]></programlisting>
  69. <para>
  70. Das <varname>$data</varname> Argument ist optional und wird verwendet um
  71. die Objekt Werte zu initialisieren. Wenn das <varname>$data</varname>
  72. unterdrückt wird, ist der Wert eine leere Zeichenkette.
  73. </para>
  74. </sect3>
  75. <sect3 id="zend.memory.memory-manager.objects-management.locked">
  76. <title>Erstellen verschlüsselter Objekte</title>
  77. <para>
  78. Verschlüsselte Objekte (Objekte, welche niemals getauscht werden) können
  79. erstellt werden mit Hilfe der
  80. <methodname>Zend_Memory_Manager::createLocked([$data])</methodname> Methode:
  81. </para>
  82. <programlisting language="php"><![CDATA[
  83. $memObject = $memoryManager->createLocked($data);
  84. ]]></programlisting>
  85. <para>
  86. Das <varname>$data</varname> Argument ist optional und wird verwendet um
  87. die Objekt Werte zu initialisieren. Wenn das <varname>$data</varname>
  88. Argument unterdrückt wird, ist der Wert eine leere Zeichenkette.
  89. </para>
  90. </sect3>
  91. <sect3 id="zend.memory.memory-manager.objects-management.destruction">
  92. <title>Objekte vernichten</title>
  93. <para>
  94. Memory Objekte werden automatische vernichtet und vom Speicher
  95. entfernt wenn sie ausserhalb des Bereichs sind:
  96. </para>
  97. <programlisting language="php"><![CDATA[
  98. function foo()
  99. {
  100. global $memoryManager, $memList;
  101. ...
  102. $memObject1 = $memoryManager->create($data1);
  103. $memObject2 = $memoryManager->create($data2);
  104. $memObject3 = $memoryManager->create($data3);
  105. ...
  106. $memList[] = $memObject3;
  107. ...
  108. unset($memObject2); // $memObject2 wird hier zerstört
  109. ...
  110. // $memObject1 wird hier zerstört
  111. // Aber das $memObject3 Objekt ist noch immer referenziert
  112. // durch $memList und ist nicht zerstört
  113. }
  114. ]]></programlisting>
  115. <para>
  116. Das gilt für beide, verschiebbare und verschlüsselte Objekte.
  117. </para>
  118. </sect3>
  119. </sect2>
  120. <sect2 id="zend.memory.memory-manager.settings">
  121. <title>Memory Manager Einstellungen</title>
  122. <sect3 id="zend.memory.memory-manager.settings.memory-limit">
  123. <title>Memory Limit</title>
  124. <para>
  125. Das Memory Limit ist eine Zahl von Bytes die zur Verwendung durch
  126. geladene verschiebbare Objekte erlaubt ist.
  127. </para>
  128. <para>
  129. Wenn das Laden oder Erstellen eines Objekts ein Überschreiten des
  130. Limits der Verwendung des Speichers verursachen würde, tauscht der
  131. Memory Manager einige andere Objekte.
  132. </para>
  133. <para>
  134. Das Memory Limit kann empfangen oder gesetzt werden durch Verwendung
  135. der <methodname>getMemoryLimit()</methodname> und
  136. <methodname>setMemoryLimit($newLimit)</methodname> Methoden:
  137. </para>
  138. <programlisting language="php"><![CDATA[
  139. $oldLimit = $memoryManager->getMemoryLimit(); // Memorylimit in Bytes empfangen
  140. $memoryManager->setMemoryLimit($newLimit); // Memorylimit in Bytes setzen
  141. ]]></programlisting>
  142. <para>
  143. Ein negativer Wert für das Memory Limit bedeutet 'kein Limit'.
  144. </para>
  145. <para>
  146. Der Standardwert ist zweidrittel des Wertes von 'memory_limit'
  147. in php.ini oder 'kein Limit' (-1) wenn 'memory_limit' in der
  148. php.ini nicht gesetzt ist.
  149. </para>
  150. </sect3>
  151. <sect3 id="zend.memory.memory-manager.settings.min-size">
  152. <title>MinSize</title>
  153. <para>
  154. MinSize ist die minimalste Größe von Memory Objekten, welche vom
  155. Memory Manager getauscht werden können. Der Memory Manager tauscht
  156. keine Objekte welche kleiner als dieser Wert sind. Das vermindert die
  157. Anzahl von Tausch-/Lade- Operationen.
  158. </para>
  159. <para>
  160. Man kann die minimale Größe empfangen oder setzen durch Verwendung der
  161. <methodname>getMinSize()</methodname> und
  162. <methodname>setMinSize($newSize)</methodname> Methoden:
  163. </para>
  164. <programlisting language="php"><![CDATA[
  165. $oldMinSize = $memoryManager->getMinSize(); // MinSize in Bytes empfangen
  166. $memoryManager->setMinSize($newSize); // MinSize Limit in Bytes setzen
  167. ]]></programlisting>
  168. <para>
  169. Die standardmäßige Wert für die minimale Größe ist 16KB (16384 bytes).
  170. </para>
  171. </sect3>
  172. </sect2>
  173. </sect1>