Zend Framework教程之Autoloading用法详解
本文实例讲述了zend framework教程之autoloading用法。分享给大家供大家参考,具体如下:
一、概述
自动加载是一种机制,无需依赖手动编写php代码。参考»php手册自动加载,一旦自动加载器被定义,你试图使用一个没有定义的类或接口的情况下,它会自动被调用。
使用自动加载,在项目中你不必担心类的存放位置。定义一个良好定义的自动加载器,您不需要考虑一个类文件相对于当前类文件的位置,您只需使用类,自动加载器将自动查找文件。
此外,自动加载,确保只加载一次,提升了性能 -所以可以用它替代require_once()。
zend framework 鼓励使用自动加载,并提供了许多工具实现自动加载代码库以及应用程序代码。下面将介绍这些工具,以及如何有效地使用它们。
自动加载的实现约定
类命名约定
zend framework借鉴了 pear的想法,即类名与文件系统的1:1的关系。简单地说,下划线字符("_")替换目录分隔,以代表该文件的路径,然后添加后缀“.php”。例如,类“foo_bar_baz”将对应文件系统上的"foo/bar/baz.php"。假设已通过php的include_path设置类的位置,这使得可以通过 include() 和 require()找到相对include_path中设置的路径查找文件名。
此外,推荐使用供应商名称或项目名称作为前缀。这意味着,你写的所有的类都有一个共同的类前缀,例如,zend framework的所有代码前缀为“zend_”。这种命名约定有助于防止命名冲突。在zendframework中,我们经常提到“namespace”前缀,要注意不要把它与php的本地命名空间混淆。
自动加载器设计约定
zend framework通过zend_loader_autoloader实现支持自动加载的,主要提供有以下目标和设计元素:
提供命名空间匹配。如果类的命名空间前缀是没有注册的命名空间,会返回false。
允许定义自动加载器作为一个备用的自动加载器。一个团队可能分布广泛,或使用一个为定义的命名空间前缀情况下,它会尝试匹配任何命名空间前缀。但是,这种做法是不推荐,因为它可能会导致不必要的查找。
允许开启禁止错误提示。 因此,默认情况下,它应该处于关闭状态。开发阶段,可以启用它。
可以自定义自动加载。一些开发商不希望使用zend_loader::loadclass()自动加载,但仍想使用zend framework的自动加载机制。 zend_loader_autoloader允许使用自定义的自动加载。
允许使用spl自动加载回调链。这样做的目的是允许指定额外的自动加载器 。
二、用法:
通常,只需将需要引入包含类,然后实例化它即可。由于zend_loader_autoloader采用的单例模式,可以使用getinstance()方法来获取一个实例。
require_once 'zend/loader/autoloader.php'; zend_loader_autoloader::getinstance();
默认情况下,可以加载命名空间前缀为"zend_"或 "zendx_"的任何类,只要确保已经指定include_path。
如果想使用其他的命名空间前缀?最好的,最简单的方法是调用registernamespace() 方法。您可以通过传递一个单一的命名空间前缀,或一个数组:
require_once 'zend/loader/autoloader.php'; $loader = zend_loader_autoloader::getinstance(); $loader->registernamespace('foo_'); $loader->registernamespace(array('foo_', 'bar_'));
或者,你可以把zend_loader_autoloader作为一个“备用”自动加载器。这意味着如果命名空间无论是否定义,都会尝试自动加载。
$loader->setfallbackautoloader(true);
(注意:这种方式是不推荐的,尽量不要使用)。
zend_loader_autoloader的内部实现是使用 zend_loader::loadclass() 加载类的。该方法的使用 include() 来尝试加载给定的类文件。 include()将返回一个布尔值,如果没有成功返回false - 而且还发出php警告。 可能会导致以下问题:
如果启用了display_errors,警告将包含在输出中。
根据你所配置的error_reporting级别,它也可以输出到日志中。
可以禁止这些错误消息,具体如下:(但注意,display_errors启用时,错误日志将始终显示。)
$autoloader->suppressnotfoundwarnings(true);
选择一个zend framework的版本
zendframework/
|-- 1.9.2/
| |-- library/
|-- zendframework-1.9.1-minimal/
| |-- library/
|-- 1.8.4pl1/
| |-- library/
|-- 1.8.4/
| |-- library/
|-- zendframework-1.8.3/
| |-- library/
|-- 1.7.8/
| |-- library/
|-- 1.7.7/
| |-- library/
|-- 1.7.6/
| |-- library/
$autoloader->setzfpath($path, 'latest');
$autoloader->setzfpath($path, '1.8');
$autoloader->setzfpath($path, '1.7.7');
也可以使用配置文件
[production] autoloaderzfpath = "path/to/zendframework" autoloaderzfversion = "1.7.7" [qa] autoloaderzfversion = "1.8" [development] autoloaderzfversion = "latest"
autoloader接口
注:命名空间前缀和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的相关方法
method | return value | parameters | description |
---|---|---|---|
getinstance() | zend_loader_autoloader | n/a |
获取实例 |
resetinstance() | void |
n/a |
重置zend_loader_autoloadersingleton实例的状态,恢复它的原始状态,注销所有的自动加载器回调和所有注册的命名空间。 |
autoload($class) | string|false |
|
试图加载一个类。 |
setdefaultautoloader($callback) | zend_loader_autoloader |
|
指定默认的加载器回调 |
getdefaultautoloader() | callback |
n/a |
获取默认的加载器接口;默认是zend_loader::loadclass(). |
setautoloaders(array $autoloaders) | zend_loader_autoloader |
|
设置在自动加载器栈使用具体的自动加载器列表。自动加载器列表中的每个项目必须是phpcallback。 |
getautoloaders() | array | n/a |
|
getnamespaceautoloaders($namespace) | array |
|
获取所有已注册的自动加载器来加载一个特定的的命名空间。 |
registernamespace($namespace) | zend_loader_autoloader |
|
注册命名空间. if$namespace is a string, it registers that namespace; if it's an array of strings, registers each as a namespace. |
unregisternamespace($namespace) | zend_loader_autoloader |
|
|
getregisterednamespaces() | array | n/a |
|
suppressnotfoundwarnings($flag = null) | boolean|zend_loader_autoloader |
|
错误提示 |
setfallbackautoloader($flag) | zend_loader_autoloader |
|
|
isfallbackautoloader() | boolean | n/a |
|
getclassautoloaders($class) | array |
|
|
unshiftautoloader($callback, $namespace = '') | zend_loader_autoloader |
|
|
pushautoloader($callback, $namespace = '') | zend_loader_autoloader |
|
|
removeautoloader($callback, $namespace = '') | zend_loader_autoloader |
|
更多关于zend相关内容感兴趣的读者可查看本站专题:《zend framework框架入门教程》、《php优秀开发框架总结》、《yii框架入门及常用技巧总结》、《thinkphp入门教程》、《php面向对象程序设计入门教程》、《php+mysql数据库操作入门教程》及《php常见数据库操作技巧汇总》
希望本文所述对大家php程序设计有所帮助。
推荐阅读
-
Zend Framework教程之Loader以及PluginLoader用法详解
-
Zend Framework教程之路由功能Zend_Controller_Router详解
-
Zend Framework教程之Autoloading用法详解
-
Zend Framework教程之前端控制器Zend_Controller_Front用法详解
-
Zend Framework路由器用法实例详解
-
Zend Framework教程之Resource Autoloading用法实例
-
Zend Framework教程之Application和Bootstrap用法详解
-
Zend Framework动作助手Redirector用法实例详解
-
Zend Framework动作助手Url用法详解
-
Zend Framework教程之MVC框架的Controller用法分析