Das Beispiel in diesem Artikel beschreibt die Verwendung von Autoloading im Zend Framework-Tutorial. Teilen Sie es als Referenz mit allen. Die Details lauten wie folgt:
1. Übersicht
Das automatische Laden ist ein Mechanismus, der kein manuelles Schreiben von PHP-Code erfordert. Siehe » PHP Manual Autoloading. Sobald der Autoloader definiert ist, wird er automatisch aufgerufen, falls Sie versuchen, eine nicht definierte Klasse oder Schnittstelle zu verwenden.
Durch das automatische Laden müssen Sie sich keine Gedanken darüber machen, wo Klassen in Ihrem Projekt gespeichert werden. Bei einem gut definierten Autoloader müssen Sie sich keine Gedanken über den Speicherort einer Klassendatei relativ zur aktuellen Klassendatei machen. Sie verwenden einfach die Klasse und der Autoloader findet die Datei automatisch.
Darüber hinaus stellt das automatische Laden sicher, dass es nur einmal geladen wird, was die Leistung verbessert – sodass es anstelle von require_once() verwendet werden kann.
Zend Framework fördert die Verwendung von Autoloading und bietet viele Tools zum automatischen Laden von Codebibliotheken und Anwendungscode. Hier ist ein Blick auf diese Tools und wie man sie effektiv nutzt.
Autoloading-Implementierungskonvention
Klassenbenennungskonvention
Zend Framework übernimmt die Idee von PEAR, was eine 1:1-Beziehung zwischen Klassennamen und Dateisystemen darstellt. Ersetzen Sie einfach das Verzeichnistrennzeichen durch den Unterstrich („_“), um den Pfad zur Datei darzustellen, und fügen Sie dann das Suffix „.php“ hinzu. Beispielsweise würde die Klasse „Foo_Bar_Baz“ „Foo/Bar/Baz.php“ im Dateisystem entsprechen. Unter der Annahme, dass der Speicherort der Klasse über PHPs include_path festgelegt wurde, können Dateinamen über include() und require() relativ zum in include_path festgelegten Pfad gefunden werden.
Außerdem wird empfohlen, den Herstellernamen oder Projektnamen als Präfix zu verwenden. Das bedeutet, dass alle von Ihnen geschriebenen Klassen ein gemeinsames Klassenpräfix haben. Beispielsweise wird dem gesamten Code im Zend Framework das Präfix „Zend_“ vorangestellt. Diese Namenskonvention hilft, Namenskonflikte zu vermeiden. In ZendFramework beziehen wir uns oft auf das Präfix „Namespace“. Achten Sie darauf, es nicht mit dem lokalen Namespace von PHP zu verwechseln.
Autoloader-Designkonvention
Zend Framework unterstützt das automatische Laden durch Zend_Loader_Autoloader, der hauptsächlich die folgenden Ziele und Designelemente bereitstellt:
Bietet Namespace-Abgleich. Wenn das Namespace-Präfix der Klasse ein nicht registrierter Namespace ist, wird FALSE zurückgegeben.
Ermöglicht die Definition eines Autoloaders als alternativen Autoloader. Ein Team kann weit verteilt sein oder ein nicht definiertes Namespace-Präfix verwenden. In diesem Fall wird versucht, mit jedem Namespace-Präfix übereinzustimmen. Dieser Ansatz wird jedoch nicht empfohlen, da er zu unnötigen Suchvorgängen führen kann.
Zulassen, dass die Unterdrückung von Fehlermeldungen aktiviert wird. Daher sollte es standardmäßig deaktiviert sein. Während der Entwicklungsphase kann es aktiviert werden.
Automatisches Laden kann angepasst werden. Einige Entwickler möchten Zend_Loader::loadClass() nicht zum automatischen Laden verwenden, möchten aber dennoch den automatischen Lademechanismus von Zend Framework verwenden. Zend_Loader_Autoloader ermöglicht die Verwendung von benutzerdefiniertem Autoloading.
Ermöglicht das automatische Laden von Rückrufketten mithilfe von SPL. Der Zweck besteht darin, die Angabe zusätzlicher Autoloader zu ermöglichen.
2. Verwendung:
Normalerweise müssen Sie den Bedarf nur in die enthaltende Klasse einführen und ihn dann instanziieren. Aufgrund des von Zend_Loader_Autoloader übernommenen Singleton-Modus können Sie die Methode getInstance() verwenden, um eine Instanz abzurufen.
require_once 'Zend/Loader/Autoloader.php'; Zend_Loader_Autoloader::getInstance();
Standardmäßig kann jede Klasse mit dem Namespace-Präfix „Zend_“ oder „ZendX_“ geladen werden. Stellen Sie lediglich sicher, dass include_path angegeben ist.
Möchten Sie andere Namespace-Präfixe verwenden? Der beste und einfachste Weg ist der Aufruf der Methode registerNamespace(). Sie können dies tun, indem Sie ein einzelnes Namespace-Präfix oder ein Array übergeben:
require_once 'Zend/Loader/Autoloader.php'; $loader = Zend_Loader_Autoloader::getInstance(); $loader->registerNamespace('Foo_'); $loader->registerNamespace(array('Foo_', 'Bar_'));
Alternativ können Sie Zend_Loader_Autoloader als „Backup“-Autoloader verwenden. Dies bedeutet, dass unabhängig davon, ob der Namespace definiert ist oder nicht, versucht wird, automatisch zu laden.
$loader->setFallbackAutoloader(true);
(Hinweis: Diese Methode wird nicht empfohlen, versuchen Sie, sie nicht zu verwenden).
Die interne Implementierung von Zend_Loader_Autoloader verwendet Zend_Loader::loadClass() zum Laden von Klassen. Diese Methode verwendet include(), um zu versuchen, die angegebene Klassendatei zu laden. include() gibt einen booleschen Wert oder FALSE zurück, wenn dies nicht erfolgreich ist – und gibt außerdem eine PHP-Warnung aus. Kann die folgenden Probleme verursachen:
Wenn display_errors aktiviert ist, werden Warnungen in die Ausgabe einbezogen.
Abhängig von der von Ihnen konfigurierten Fehlerberichtsebene kann es auch im Protokoll ausgegeben werden.
Diese Fehlermeldungen können wie folgt unterdrückt werden: (Beachten Sie jedoch, dass das Fehlerprotokoll immer angezeigt wird, wenn display_errors aktiviert ist.)
$autoloader->suppressNotFoundWarnings(true);
Wählen Sie eine Version von Zend Framework
ZendFramework/
|-- 1.9.2/
| |-- Library/
|-- ZendFramework-1.9.1-minimal/
|. |. -- Bibliothek/
|-- 1.8.4PL1/
|-- 1.8.4/
|. - ZendFramework- 1.8.3/
|. |-- Bibliothek/
|. |-- Bibliothek/
| -- Bibliothek /
|-- 1.7.6/
|
$autoloader->setZfPath($path, 'latest');
$autoloader->setZfPath($path, '1.8');
$autoloader->setZfPath($path, '1.7.7');
注:命名空间前缀和PHP命名空间
PHP5.3已经发布。该版本中,PHP现在已经正式支持命名空间。
然而,Zend Framework的命名空间和PHP 5.3的命名空间完全不同的。 Zend Framework中,提到的“命名空间”,是指一个类前缀。例如,所有的Zend Framework的类名称的前缀“Zend_”。 这是我们指定的“命名空间”。
在Zend Framework 2.0.0使用了原生的PHP命名空间。
自动加载器除了能够指定任意回调以外,Zend Framework还定义了一个需要自动加载类实现的接口Zend_Loader_Autoloader_Interface:
interface Zend_Loader_Autoloader_Interface { public function autoload($class); }
如果您希望在Zend Framework中使用自定义的自动加载器,可以使用 Zend_Loader_Autoloader的 pushAutoloader()和unshiftAutoloader()方法。
通过这些方法将在Zend Framework的内部自动装载器之后追加或之前使用自定义的加载器。
每个方法接受一个可选的第二个参数,类的命名空间前缀。自动加载器只查找给定的类前缀。如果不是指定的类前缀,将跳过自动加载器 , 这可能是一种性能改进方式。
当使用这个接口时,你需要传递类实例到Zend_Loader_Autoloader类的pushAutoloader()和unshiftAutoloader()方法,具体如下:
// Append function 'my_autoloader' to the stack, // to manage classes with the prefix 'My_': $loader->pushAutoloader('my_autoloader', 'My_'); // Prepend static method Foo_Loader::autoload() to the stack, // to manage classes with the prefix 'Foo_': $loader->unshiftAutoloader(array('Foo_Loader', 'autoload'), 'Foo_'); // Assume Foo_Autoloader implements Zend_Loader_Autoloader_Interface: $foo = new Foo_Autoloader(); $autoloader->pushAutoloader($foo, 'Foo_');
Zend_Loader_Autoloader的相关方法
希望本文所述对大家PHP程序设计有所帮助。
更多 Zend Framework教程之Autoloading用法详解相关文章请关注PHP中文网!