Zend_Memory-Overview.xml 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153
  1. <sect1 id="zend.memory.overview">
  2. <title>概述</title>
  3. <sect2 id="zend.memory.introduction">
  4. <title> 简介 </title>
  5. <para>
  6. Zend_Memory组件用于在一个受限制的内存环境下管理数据.
  7. </para>
  8. <para>
  9. 内存对象(内存容器)是由内存管理器按照请求生成并在需要的时候透明地交换/加载的.
  10. </para>
  11. <para>
  12. 例如,如果由于受管理对象的创建或加载导致内存使用量超过你所指定的限制,一些管理对象将被复制到内存以外的缓存存储中.
  13. 用这种方法,受管理对象的总内存使用量不会超过强制的限制.
  14. </para>
  15. <para>
  16. 内存管理器使用<link linkend="zend.cache.backends">Zend_Cache backends</link>作为存储提供者
  17. </para>
  18. <example id="zend.memory.introduction.example-1">
  19. <title>使用 Zend_Memory 组件</title>
  20. <para>
  21. <code>Zend_Memory::factory()</code> 用指定的后端选项实例化内存管理器对象.
  22. </para>
  23. <programlisting role="php"><![CDATA[
  24. require_once 'Zend/Memory.php';
  25. $backendOptions = array(
  26. 'cache_dir' => './tmp/' // Directory where to put the swapped memory blocks
  27. );
  28. $memoryManager = Zend_Memory::factory('File', $backendOptions);
  29. $loadedFiles = array();
  30. for ($count = 0; $count < 10000; $count++) {
  31. $f = fopen($fileNames[$count], 'rb');
  32. $data = fread($f, filesize($fileNames[$count]));
  33. $fclose($f);
  34. $loadedFiles[] = $memoryManager->create($data);
  35. }
  36. echo $loadedFiles[$index1]->value;
  37. $loadedFiles[$index2]->value = $newValue;
  38. $loadedFiles[$index3]->value[$charIndex] = '_';
  39. ]]>
  40. </programlisting>
  41. </example>
  42. </sect2>
  43. <sect2 id="zend.memory.theory-of-operation">
  44. <title>操作原理</title>
  45. <para>
  46. Zend_Memory 组件操作有如下的概念:
  47. <itemizedlist>
  48. <listitem>
  49. <para>内存管理器</para>
  50. </listitem>
  51. <listitem>
  52. <para>内存容器</para>
  53. </listitem>
  54. <listitem>
  55. <para>锁定的内存对象</para>
  56. </listitem>
  57. <listitem>
  58. <para>可移动的内存对象</para>
  59. </listitem>
  60. </itemizedlist>
  61. </para>
  62. <sect3 id="zend.memory.theory-of-operation.manager">
  63. <title>内存管理器</title>
  64. <para>
  65. 内存管理器按照用户应用程序的请求生成内存对象(锁定的或可移动的)并返回已交换到内存容器对象中的那些.
  66. </para>
  67. </sect3>
  68. <sect3 id="zend.memory.theory-of-operation.container">
  69. <title>内存容器</title>
  70. <para>
  71. 内存容器有一个虚拟的或者实际的字符串类型的<code>值</code>.
  72. 这个属性包含了在内存对象创建时指定的数据值.
  73. </para>
  74. <para>
  75. 你可以作为对象属性操作这个<code>值</code>属性:
  76. <programlisting role="php"><![CDATA[
  77. $memObject = $memoryManager->create($data);
  78. echo $memObject->value;
  79. $memObject->value = $newValue;
  80. $memObject->value[$index] = '_';
  81. echo ord($memObject->value[$index1]);
  82. $memObject->value = substr($memObject->value, $start, $length);
  83. ]]>
  84. </programlisting>
  85. </para>
  86. <note>
  87. <para>
  88. 如果你使用的PHP版本小于5.2,使用<link linkend="zend.memory.memory-objects.api.getRef">getRef()</link>
  89. 方法而不是直接访问属性值.
  90. </para>
  91. </note>
  92. </sect3>
  93. <sect3 id="zend.memory.theory-of-operation.locked">
  94. <title>锁定的内存</title>
  95. <para>
  96. 锁定的内存对象总是存储在内存中.存储在锁定内存对象中的数据绝不会被交换到缓存后端中去.
  97. </para>
  98. </sect3>
  99. <sect3 id="zend.memory.theory-of-operation.movable">
  100. <title>可移动内存</title>
  101. <para>
  102. 当需要时,可移动内存对象由Zend_Memory透明的交换到缓存后端或则从缓存后端加载.
  103. </para>
  104. <para>
  105. 由于性能的考虑,内存管理器不会交换小于指定大小的内存对象.细节请查看
  106. <xref linkend="zend.memory.memory-manager.settings.min-size" />
  107. </para>
  108. </sect3>
  109. </sect2>
  110. </sect1>