Zend_Loader-Autoloader.xml 29 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- Reviewed: no -->
  3. <sect1 id="zend.loader.autoloader">
  4. <title>Автозагрузчик</title>
  5. <para>
  6. <classname>Zend_Loader_Autoloader</classname> представляет собой
  7. комплексное решение для автозагрузки. Он разрабатывался для следующих
  8. целей:
  9. </para>
  10. <itemizedlist>
  11. <listitem><para>
  12. Предоставление настоящего автозарузчика пространств имен
  13. (предыдущие реализации перехватывали все пространства имен подряд).
  14. </para></listitem>
  15. <listitem><para>
  16. Возможность регистрации любых обратных вызовов в качестве
  17. автозагрузчиков и управления ими как стеком (на момент написания
  18. данного текста он позволяет обойти некоторые проблемы с
  19. <code>spl_autoload</code>,
  20. которые не позволяют заново регистрировать обратные вызовы,
  21. использующие методы экземпляра).
  22. </para></listitem>
  23. <listitem><para>
  24. Возможность оптимистического сопоставления (optimistic matching)
  25. пространств имен для более быстрого определения пути к подключаемому
  26. классу.
  27. </para></listitem>
  28. </itemizedlist>
  29. <para>
  30. <classname>Zend_Loader_Autoloader</classname> реализован в виде
  31. синглетона, что делает его доступным из любого места.
  32. Это дает возможность регистрировать дополнительные автозагрузчики
  33. в любой момент выполнения, когда это необходимо.
  34. </para>
  35. <sect2 id="zend.loader.autoloader.usage">
  36. <title>Использование автозагрузчика</title>
  37. <para>
  38. Когда экземпляр автозагрузчика извлекается в первый раз,
  39. он регистрирует себя через <code>spl_autoload</code>.
  40. Вы извлекаете экземпляр, используя метод <code>getInstance()</code>:
  41. </para>
  42. <programlisting language="php"><![CDATA[
  43. $autoloader = Zend_Loader_Autoloader::getInstance();
  44. ]]></programlisting>
  45. <para>
  46. По умолчанию автозагрузчик сконфигурирован с тем, чтобы
  47. соответствовать пространствам имен "Zend_" и "ZendX_".
  48. Если у вас есть есть своя библиотека, которая используют
  49. собственное пространство имен, то вы можете зарегистрировать его
  50. в автозагрузчике, используя метод <code>registerNamespace()</code>.
  51. Например, если ваша библиотека представлена префиксом "My_", то вы
  52. можете сделать это следующим образом:
  53. </para>
  54. <programlisting language="php"><![CDATA[
  55. $autoloader->registerNamespace('My_');
  56. ]]></programlisting>
  57. <note>
  58. <title>Префиксы пространств имен</title>
  59. <para>
  60. Обратите внимание, что предыдущий пример использует в
  61. качестве префикса "My_", а не "My". Это из-за того, что
  62. <classname>Zend_Loader_Autoloader</classname> задуман как
  63. загрузчик общего назначения, и не предполагает,
  64. что префикс пространства имен должен включать в себя знак
  65. подчеркивания. Если ваше пространство имен классов
  66. включает в себя знак подчеркивания, то вы должны указывать его
  67. при регистрации вашего пространства имен.
  68. </para>
  69. </note>
  70. <para>
  71. Вы можете также регистрировать любые обратные вызовы для
  72. автозагрузки, опционально с определенным пространством имен (или
  73. группой пространств имен).
  74. <classname>Zend_Loader_Autoloader</classname> будет искать
  75. соответствие им до того, как использовать свой встроенный
  76. механизм автозагрузки.
  77. </para>
  78. <para>
  79. Например, вам можете захотеть использовать одну или более
  80. компонент из eZcomponents в своем приложении на основе
  81. Zend Framework. Для того, чтобы использовать возможности
  82. eZcomponents по автозагрузке, добавьте его автозагрузчик в стек,
  83. используя <code>pushAutoloader()</code>:
  84. </para>
  85. <programlisting language="php"><![CDATA[
  86. $autoloader->pushAutoloader(array('ezcBase', 'autoload'), 'ezc');
  87. ]]></programlisting>
  88. <para>
  89. Это говорит автозагрузчику, чтобы он использовал автозагрузчик
  90. eZcomponents для классов, начинающихся с "ezc".
  91. </para>
  92. <para>
  93. Вы можете использовать метод <code>unshiftAutoloader()</code>
  94. для добавления автозагрузчика в начало цепочки автозагрузчиков.
  95. </para>
  96. <para>
  97. По умолчанию <classname>Zend_Loader_Autoloader</classname> не
  98. подавляет ошибки при использовании его внутреннего автозагрузчика,
  99. который использует <classname>Zend_Loader::loadClass()</classname>.
  100. В большинстве случаев это именно то, чего вы хотите.
  101. Тем не менее, могут быть случаи, когда может потребоваться подавлять
  102. их. Вы можете сделать это, используя метод
  103. <code>suppressNotFoundWarnings()</code>:
  104. </para>
  105. <programlisting language="php"><![CDATA[
  106. $autoloader->suppressNotFoundWarnings(true);
  107. ]]></programlisting>
  108. <para>
  109. И наконец, иногда может потребоваться, чтобы автозагрузчик загружал
  110. все пространства имен. Например, библиотеки PEAR не используют
  111. общего пространства имен, что делает указание отдельных
  112. пространств имен затруднительным, если используется много компонент
  113. из PEAR. Вы можете использовать метод
  114. <code>setFallbackAutoloader()</code>
  115. для того, чтобы данный автозагрузчик был универсальным для всех
  116. пространств имен:
  117. </para>
  118. <programlisting language="php"><![CDATA[
  119. $autoloader->setFallbackAutoloader(true);
  120. ]]></programlisting>
  121. </sect2>
  122. <sect2 id="zend.loader.autoloader.interface">
  123. <title>Итерфейс автозагрузчика</title>
  124. <para>
  125. Кроме возможности указывать любые обратные вызовы в качестве
  126. автозагрузчиков, Zend Framework предоставляет интерфейс,
  127. который классы автозагрузчиков могут реализовывать -
  128. <classname>Zend_Loader_Autoloader_Interface</classname>:
  129. </para>
  130. <programlisting language="php"><![CDATA[
  131. interface Zend_Loader_Autoloader_Interface
  132. {
  133. public function autoload($class);
  134. }
  135. ]]></programlisting>
  136. <para>
  137. Используя этот интерфейс, вы можете передавать экземпляр
  138. класса методам <classname>Zend_Loader_Autoloader</classname>-а
  139. <code>pushAutoloader()</code> и <code>unshiftAutoloader()</code>:
  140. </para>
  141. <programlisting language="php"><![CDATA[
  142. // Предполагается, что Foo_Autoloader реализует Zend_Loader_Autoloader_Interface:
  143. $foo = new Foo_Autoloader();
  144. $autoloader->pushAutoloader($foo, 'Foo_');
  145. ]]></programlisting>
  146. </sect2>
  147. <sect2 id="zend.loader.autoloader.reference">
  148. <title>Справка по автозагрузчику</title>
  149. <para>
  150. Ниже приведено руководство по методам, доступным в классе
  151. <classname>Zend_Loader_Autoloader</classname>.
  152. </para>
  153. <table id="zend.loader.autoloader.reference.api">
  154. <title>Методы Zend_Loader_Autoloader-а</title>
  155. <tgroup cols="4">
  156. <thead>
  157. <row>
  158. <entry>Метод</entry>
  159. <entry>Возвращаемое значение</entry>
  160. <entry>Параметры</entry>
  161. <entry>Описание</entry>
  162. </row>
  163. </thead>
  164. <tbody>
  165. <row>
  166. <entry><code>getInstance()</code></entry>
  167. <entry><classname>Zend_Loader_Autoloader</classname></entry>
  168. <entry>Нет</entry>
  169. <entry><para>
  170. Возвращает экземпляр-синглетон класса
  171. <classname>Zend_Loader_Autoloader</classname>.
  172. При первом извлечении он регистрирует
  173. себя через <code>spl_autoload</code>.
  174. Этот метод является статическим.
  175. </para></entry>
  176. </row>
  177. <row>
  178. <entry><code>resetInstance()</code></entry>
  179. <entry><code>void</code></entry>
  180. <entry>Нет</entry>
  181. <entry><para>
  182. Устанавливает состояние экземпляра-синглетона
  183. <classname>Zend_Loader_Autoloader</classname>
  184. в его исходное состояние, отменяя регистрацию
  185. всех обратных вызовов и всех зарегистрированных
  186. пространств имен.
  187. </para></entry>
  188. </row>
  189. <row>
  190. <entry><code>autoload($class)</code></entry>
  191. <entry><code>string|false</code></entry>
  192. <entry><itemizedlist>
  193. <listitem><para>
  194. <varname>$class</varname>, <emphasis>обязательный</emphasis>.
  195. Строка с именем класса для загрузки.
  196. </para></listitem>
  197. </itemizedlist></entry>
  198. <entry><para>
  199. Пытается определить путь к файлу по имени класса
  200. и загрузить его.
  201. </para></entry>
  202. </row>
  203. <row>
  204. <entry><code>setDefaultAutoloader($callback)</code></entry>
  205. <entry><classname>Zend_Loader_Autoloader</classname></entry>
  206. <entry><itemizedlist>
  207. <listitem><para>
  208. <varname>$callback</varname>, <emphasis>обязательный</emphasis>.
  209. </para></listitem>
  210. </itemizedlist></entry>
  211. <entry><para>
  212. Указывает альтернативный обратный вызов для
  213. применения в используемой по умолчанию реализации
  214. автозагрузчика.
  215. </para></entry>
  216. </row>
  217. <row>
  218. <entry><code>getDefaultAutoloader()</code></entry>
  219. <entry><code>callback</code></entry>
  220. <entry>Нет</entry>
  221. <entry><para>
  222. Возвращает используемую по умолчанию реализацию
  223. автозагрузчика; по умолчанию это
  224. <classname>Zend_Loader::loadClass()</classname>.
  225. </para></entry>
  226. </row>
  227. <row>
  228. <entry><code>setAutoloaders(array $autoloaders)</code></entry>
  229. <entry><classname>Zend_Loader_Autoloader</classname></entry>
  230. <entry><itemizedlist>
  231. <listitem><para>
  232. <varname>$autoloaders</varname>, <emphasis>обязательный</emphasis>.
  233. </para></listitem>
  234. </itemizedlist></entry>
  235. <entry><para>
  236. Устанавливает список автозагрузчиков для
  237. использования в стеке автозагрузчиков.
  238. Каждый элемент в массиве автозагрузчиков должен быть
  239. обратным вызовом PHP.
  240. </para></entry>
  241. </row>
  242. <row>
  243. <entry><code>getAutoloaders()</code></entry>
  244. <entry><type>Array</type></entry>
  245. <entry>Нет</entry>
  246. <entry><para>
  247. Возвращает внутренний стек автозагрузчиков.
  248. </para></entry>
  249. </row>
  250. <row>
  251. <entry><code>getNamespaceAutoloaders($namespace)</code></entry>
  252. <entry><type>Array</type></entry>
  253. <entry><itemizedlist>
  254. <listitem><para>
  255. <varname>$namespace</varname>, <emphasis>обязательный</emphasis>
  256. </para></listitem>
  257. </itemizedlist></entry>
  258. <entry><para>
  259. Извлекает все автозагрузчики, которые были
  260. зарегистрированы для загрузки данного
  261. пространства имен.
  262. </para></entry>
  263. </row>
  264. <row>
  265. <entry><code>registerNamespace($namespace)</code></entry>
  266. <entry><classname>Zend_Loader_Autoloader</classname></entry>
  267. <entry><itemizedlist>
  268. <listitem><para>
  269. <varname>$namespace</varname>, <emphasis>обязательный</emphasis>.
  270. </para></listitem>
  271. </itemizedlist></entry>
  272. <entry><para>
  273. Регистрирует одно или более пространств имен с
  274. используемым по умолчанию автозагрузчиком.
  275. Если <varname>$namespace</varname> является строкой,
  276. то она регистрируется как пространство имен;
  277. если же массив строк, то все они
  278. регистрируются как пространства имен.
  279. </para></entry>
  280. </row>
  281. <row>
  282. <entry><code>unregisterNamespace($namespace)</code></entry>
  283. <entry><classname>Zend_Loader_Autoloader</classname></entry>
  284. <entry><itemizedlist>
  285. <listitem><para>
  286. <varname>$namespace</varname>, <emphasis>обязательный</emphasis>.
  287. </para></listitem>
  288. </itemizedlist></entry>
  289. <entry><para>
  290. Отменяет регистрацию одного или более пространств
  291. имен из используемого по умолчанию автозагрузчика.
  292. Если <varname>$namespace</varname> является строкой,
  293. то отменяется регистрация пространства имен
  294. под этим именем;
  295. если это массив строк, то отменяются
  296. регистрации всех пространств имен в этом массиве.
  297. </para></entry>
  298. </row>
  299. <row>
  300. <entry><code>getRegisteredNamespace()</code></entry>
  301. <entry><type>Array</type></entry>
  302. <entry>Нет</entry>
  303. <entry><para>
  304. Возвращает массив пространств имен,
  305. зарегистрированных с используемым по умолчанию
  306. автозагрузчиком.
  307. </para></entry>
  308. </row>
  309. <row>
  310. <entry><code>suppressNotFoundWarnings($flag = null)</code></entry>
  311. <entry><code>boolean|Zend_Loader_Autoloader</code></entry>
  312. <entry><itemizedlist>
  313. <listitem><para>
  314. <varname>$flag</varname>, <emphasis>опциональный</emphasis>.
  315. </para></listitem>
  316. </itemizedlist></entry>
  317. <entry><para>
  318. Устанавливает или возвращает значение флага,
  319. который используется для указания того, должна ли
  320. применяемая по умолчанию реализация автозагрузчика
  321. подавлять предупреждение "файл не найден"
  322. ("file not found"). Если ему не передаются аргументы
  323. или передано значение null, то он возвращает
  324. булево значение, показывающее статус флага.
  325. Если же передано булево значение, то флаг
  326. принимает данное значение и возвращается
  327. экземпляр автозагрузчика (для возможности
  328. использования method chaining).
  329. </para></entry>
  330. </row>
  331. <row>
  332. <entry><code>setFallbackAutoloader($flag)</code></entry>
  333. <entry><classname>Zend_Loader_Autoloader</classname></entry>
  334. <entry><itemizedlist>
  335. <listitem><para>
  336. <varname>$flag</varname>, <emphasis>обязательный</emphasis>.
  337. </para></listitem>
  338. </itemizedlist></entry>
  339. <entry><para>
  340. Устанавливает значение флага, который используется
  341. для указания того, должен или нет применяемый по
  342. умолчанию автозагрузчик использоваться в качестве
  343. обратного вызова или универсального автозагрузчика
  344. для всех пространств имен.
  345. </para></entry>
  346. </row>
  347. <row>
  348. <entry><code>isFallbackAutoloader()</code></entry>
  349. <entry><type>Boolean</type></entry>
  350. <entry>Нет</entry>
  351. <entry><para>
  352. Возвращает значение флага, который используется для
  353. указания того, должен или нет применяемый по
  354. умолчанию автозагрузчик использоваться в качестве
  355. обратного вызова или универсального автозагрузчика
  356. для всех пространств имен.
  357. По умолчанию его значение равно false.
  358. </para></entry>
  359. </row>
  360. <row>
  361. <entry><code>getClassAutoloaders($class)</code></entry>
  362. <entry><type>Array</type></entry>
  363. <entry><itemizedlist>
  364. <listitem><para>
  365. <varname>$class</varname>, <emphasis>обязательный</emphasis>.
  366. </para></listitem>
  367. </itemizedlist></entry>
  368. <entry><para>
  369. Возвращает список автозагрузчиков, которые могут
  370. соответствовать данному классу. Если нет ни одного
  371. подходящего автозагрузчика, то возвращаются все
  372. глобальные (без привязки к пространству имен)
  373. автозагрузчики.
  374. </para></entry>
  375. </row>
  376. <row>
  377. <entry><code>unshiftAutoloader($callback, $namespace = '')</code></entry>
  378. <entry><classname>Zend_Loader_Autoloader</classname></entry>
  379. <entry><itemizedlist>
  380. <listitem><para>
  381. <varname>$callback</varname>, <emphasis>обязательный</emphasis>.
  382. Обратный вызов PHP
  383. </para></listitem>
  384. <listitem><para>
  385. <varname>$namespace</varname>, <emphasis>опциональный</emphasis>.
  386. Строка с префиксом имен классов, используемым в
  387. качестве пространства имен.
  388. </para></listitem>
  389. </itemizedlist></entry>
  390. <entry><para>
  391. Добавляет конкретную реализацию автозагрузчика
  392. в начало внутреннего стека автозагрузчиков. Если
  393. было передано пространство имен, то оно будет
  394. использовано для оптимистического сопоставления
  395. (optimistic matching), иначе автозагрузчик будет
  396. использоваться в качестве глобального.
  397. </para></entry>
  398. </row>
  399. <row>
  400. <entry><code>pushAutoloader($callback, $namespace = '')</code></entry>
  401. <entry><classname>Zend_Loader_Autoloader</classname></entry>
  402. <entry><itemizedlist>
  403. <listitem><para>
  404. <varname>$callback</varname>, <emphasis>обязательный</emphasis>.
  405. Обратный вызов PHP
  406. </para></listitem>
  407. <listitem><para>
  408. <varname>$namespace</varname>, <emphasis>опциональный</emphasis>.
  409. Строка с префиксом имен классов, используемым в
  410. качестве пространства имен.
  411. </para></listitem>
  412. </itemizedlist></entry>
  413. <entry><para>
  414. Добавляет конкретную реализацию автозагрузчика
  415. в конец внутреннего стека автозагрузчиков. Если
  416. было передано пространство имен, то оно будет
  417. использовано для оптимистического сопоставления
  418. (optimistic matching), иначе автозагрузчик будет
  419. использоваться в качестве глобального.
  420. </para></entry>
  421. </row>
  422. <row>
  423. <entry><code>removeAutoloader($callback, $namespace = '')</code></entry>
  424. <entry><classname>Zend_Loader_Autoloader</classname></entry>
  425. <entry><itemizedlist>
  426. <listitem><para>
  427. <varname>$callback</varname>, <emphasis>обязательный</emphasis>.
  428. Обратный вызов PHP
  429. </para></listitem>
  430. <listitem><para>
  431. <varname>$namespace</varname>, <emphasis>опциональный</emphasis>.
  432. Строка, представляющая собой префикс имен
  433. классов (используемый в качестве пространства
  434. имен) или массив строк с префиксами.
  435. </para></listitem>
  436. </itemizedlist></entry>
  437. <entry><para>
  438. Удаляет конкретную реализацию автозагрузчика из
  439. внутреннего стека автозагрузчиков.
  440. Если предоставлено пространство (пространства) имен,
  441. то обратный вызов будет удален только для данного
  442. пространства (пространств) имен.
  443. </para></entry>
  444. </row>
  445. </tbody>
  446. </tgroup>
  447. </table>
  448. </sect2>
  449. </sect1>