Zend_Memory-MemoryObjects.xml 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- Reviewed: no -->
  3. <!-- EN-Revision: 15103 -->
  4. <sect1 id="zend.memory.memory-objects">
  5. <title>メモリオブジェクト</title>
  6. <sect2 id="zend.memory.memory-objects.movable">
  7. <title>移動可能なオブジェクト</title>
  8. <para>
  9. 移動可能なメモリオブジェクトを作成するには、メモリマネージャの
  10. <code>create([$data])</code> メソッドを使用します。
  11. <programlisting role="php"><![CDATA[
  12. $memObject = $memoryManager->create($data);
  13. ]]>
  14. </programlisting>
  15. </para>
  16. <para>
  17. "移動可能" とは、このオブジェクトがスワップされ、
  18. メモリから削除される可能性があるということです。
  19. アプリケーションがこのオブジェクトにアクセスする際に、
  20. 再度メモリに読み込まれます。
  21. </para>
  22. </sect2>
  23. <sect2 id="zend.memory.memory-objects.locked">
  24. <title>ロックされたオブジェクト</title>
  25. <para>
  26. ロックされたメモリオブジェクトを作成するには、メモリマネージャの
  27. <code>createLocked([$data])</code> メソッドを使用します。
  28. <programlisting role="php"><![CDATA[
  29. $memObject = $memoryManager->createLocked($data);
  30. ]]>
  31. </programlisting>
  32. </para>
  33. <para>
  34. "ロックされた" とは、このオブジェクトは決してスワップされず、
  35. メモリから削除されないということです。
  36. </para>
  37. <para>
  38. ロックされたオブジェクトは、移動可能なオブジェクトと同じインターフェイス
  39. (<classname>Zend_Memory_Container_Interface</classname>) を提供します。
  40. したがって、ロックされたオブジェクトは
  41. どんな場面でも、移動可能なオブジェクトのかわりに使用することができます。
  42. </para>
  43. <para>
  44. パフォーマンスを考慮し、一部のオブジェクトは
  45. スワップさせないようにしたいなどといった場合に、これは有用です。
  46. </para>
  47. <para>
  48. ロックされたオブジェクトへのアクセスはより高速になります。
  49. というのも、メモリマネージャがそのオブジェクトの変更内容を追いかける必要がないからです。
  50. </para>
  51. <para>
  52. ロックされたオブジェクトのクラス (<classname>Zend_Memory_Container_Locked</classname>)
  53. は、通常の文字列変数と事実上同程度のパフォーマンスを保証します。
  54. オーバーヘッドとなるのは、クラスのプロパティを取得する際の参照の解決のみです。
  55. </para>
  56. </sect2>
  57. <sect2 id="zend.memory.memory-objects.value">
  58. <title>メモリコンテナの 'value' プロパティ</title>
  59. <para>
  60. (移動可能な、あるいはロックされた) メモリコンテナの '<code>value</code>'
  61. プロパティを使用して、メモリオブジェクトのデータを扱います。
  62. <programlisting role="php"><![CDATA[
  63. $memObject = $memoryManager->create($data);
  64. echo $memObject->value;
  65. $memObject->value = $newValue;
  66. $memObject->value[$index] = '_';
  67. echo ord($memObject->value[$index1]);
  68. $memObject->value = substr($memObject->value, $start, $length);
  69. ]]>
  70. </programlisting>
  71. </para>
  72. <para>
  73. メモリオブジェクトのデータにアクセスするもうひとつの方法として、
  74. <link linkend="zend.memory.memory-objects.api.getRef"><code>getRef()</code></link>
  75. メソッドを使うものがあります。PHP のバージョンが 5.2 より古い場合は、
  76. <emphasis>必ず</emphasis> このメソッドを使用しなければなりません。
  77. パフォーマンスの問題から、その他の場合にもこれを使わなければならないことがあるかもしれません。
  78. </para>
  79. </sect2>
  80. <sect2 id="zend.memory.memory-objects.api">
  81. <title>メモリコンテナのインターフェイス</title>
  82. <para>
  83. メモリコンテナは、以下のメソッドを提供します。
  84. </para>
  85. <sect3 id="zend.memory.memory-objects.api.getRef">
  86. <title>getRef() メソッド</title>
  87. <programlisting role="php"><![CDATA[
  88. public function &getRef();
  89. ]]>
  90. </programlisting>
  91. <para>
  92. <code>getRef()</code> メソッドは、オブジェクトの値への参照を返します。
  93. </para>
  94. <para>
  95. 移動可能なオブジェクトは、もしメモリ内になければ
  96. この時点でキャッシュから読み込まれます。
  97. オブジェクトをキャッシュから読み込んだ場合に、
  98. メモリ内で管理しているオブジェクトのサイズが制限に達すると、
  99. 他のオブジェクトのスワップが発生します。
  100. </para>
  101. <para>
  102. PHP のバージョンが 5.2 より古い場合、メモリオブジェクトのデータにアクセスするには
  103. <emphasis>必ず</emphasis> <code>getRef()</code>
  104. メソッドを使用する必要があります。
  105. </para>
  106. <para>
  107. データの変更内容を追いかけるには、余分なリソースが必要となります。
  108. <code>getRef()</code> メソッドは文字列への参照を返し、
  109. これはアプリケーションから直接変更することになります。
  110. つまり、データの内容を処理する際には <code>getRef()</code>
  111. メソッドを使用するのがうまいやり方となります。
  112. <programlisting role="php"><![CDATA[
  113. $memObject = $memoryManager->create($data);
  114. $value = &$memObject->getRef();
  115. for ($count = 0; $count < strlen($value); $count++) {
  116. $char = $value[$count];
  117. ...
  118. }
  119. ]]>
  120. </programlisting>
  121. </para>
  122. </sect3>
  123. <sect3 id="zend.memory.memory-objects.api.touch">
  124. <title>touch() メソッド</title>
  125. <programlisting role="php"><![CDATA[
  126. public function touch();
  127. ]]>
  128. </programlisting>
  129. <para>
  130. <code>touch()</code> メソッドは
  131. <code>getRef()</code> と同じように使用しなければなりません。
  132. これは、オブジェクトの値が変更されたことを通知します。
  133. <programlisting role="php"><![CDATA[
  134. $memObject = $memoryManager->create($data);
  135. ...
  136. $value = &$memObject->getRef();
  137. for ($count = 0; $count < strlen($value); $count++) {
  138. ...
  139. if ($condition) {
  140. $value[$count] = $char;
  141. }
  142. ...
  143. }
  144. $memObject->touch();
  145. ]]>
  146. </programlisting>
  147. </para>
  148. </sect3>
  149. <sect3 id="zend.memory.memory-objects.api.lock">
  150. <title>lock() メソッド</title>
  151. <programlisting role="php"><![CDATA[
  152. public function lock();
  153. ]]>
  154. </programlisting>
  155. <para>
  156. <code>lock()</code> メソッドは、オブジェクトをメモリ内にロックします。
  157. これを使用して、スワップしたくないオブジェクトを選択します。
  158. 通常はこれは不要です。なぜなら、メモリマネージャが
  159. うまい具合にスワップする候補を選ぶようにできているからです。
  160. しかし、どうしてもスワップしてはならないオブジェクトがあることがわかっている場合は、
  161. それをロックするとよいでしょう。
  162. </para>
  163. <para>
  164. オブジェクトをメモリ内にロックすることで、ロックを解除するまでは
  165. <code>getRef()</code> メソッドの返す参照が有効であることが保証されます。
  166. <programlisting role="php"><![CDATA[
  167. $memObject1 = $memoryManager->create($data1);
  168. $memObject2 = $memoryManager->create($data2);
  169. ...
  170. $memObject1->lock();
  171. $memObject2->lock();
  172. $value1 = &$memObject1->getRef();
  173. $value2 = &$memObject2->getRef();
  174. for ($count = 0; $count < strlen($value2); $count++) {
  175. $value1 .= $value2[$count];
  176. }
  177. $memObject1->touch();
  178. $memObject1->unlock();
  179. $memObject2->unlock();
  180. ]]>
  181. </programlisting>
  182. </para>
  183. </sect3>
  184. <sect3 id="zend.memory.memory-objects.api.unlock">
  185. <title>unlock() メソッド</title>
  186. <programlisting role="php"><![CDATA[
  187. public function unlock();
  188. ]]>
  189. </programlisting>
  190. <para>
  191. <code>unlock()</code> メソッドは、
  192. ロックが不要となったオブジェクトのロックを解除します。
  193. 上の例を参照ください。
  194. </para>
  195. </sect3>
  196. <sect3 id="zend.memory.memory-objects.api.isLocked">
  197. <title>isLocked() メソッド</title>
  198. <programlisting role="php"><![CDATA[
  199. public function isLocked();
  200. ]]>
  201. </programlisting>
  202. <para>
  203. <code>isLocked()</code> メソッドを使用して、
  204. オブジェクトがロックされているかどうかを調べます。
  205. オブジェクトがロックされている場合は <code>true</code>、
  206. ロックされていない場合は <code>false</code> を返します。
  207. "ロックされている" オブジェクトについては、これは常に
  208. <code>true</code> を返します。また "移動可能な" オブジェクトの場合は
  209. <code>true</code> あるいは <code>false</code> のいずれかを返します。
  210. </para>
  211. </sect3>
  212. </sect2>
  213. </sect1>