Zend Framework教程之Autoloading用法详解


Posted in PHP onMarch 08, 2016

本文实例讲述了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 $class,required. A string class name to load. 试图加载一个类。
setDefaultAutoloader($callback) Zend_Loader_Autoloader $callback,required. 指定默认的加载器回调
getDefaultAutoloader() callback N/A 获取默认的加载器接口;默认是Zend_Loader::loadClass().
setAutoloaders(array $autoloaders) Zend_Loader_Autoloader $autoloaders,required. 设置在自动加载器栈使用具体的自动加载器列表。自动加载器列表中的每个项目必须是PHPcallback。
getAutoloaders() Array N/A  
getNamespaceAutoloaders($namespace) Array $namespace,required 获取所有已注册的自动加载器来加载一个特定的的命名空间。
registerNamespace($namespace) Zend_Loader_Autoloader $namespace,required. 注册命名空间. 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 $namespace,required.
getRegisteredNamespaces() Array N/A
suppressNotFoundWarnings($flag = null) boolean|Zend_Loader_Autoloader $flag,optional. 错误提示
setFallbackAutoloader($flag) Zend_Loader_Autoloader $flag,required.  
isFallbackAutoloader() Boolean N/A  
getClassAutoloaders($class) Array $class,required.  
unshiftAutoloader($callback, $namespace = '') Zend_Loader_Autoloader $callback,required. A valid PHPcallback $namespace,optional. A string representing a class prefix namespace.  
pushAutoloader($callback, $namespace = '') Zend_Loader_Autoloader $callback,required. A valid PHPcallback $namespace,optional. A string representing a class prefix namespace.  
removeAutoloader($callback, $namespace = '') Zend_Loader_Autoloader $callback,required. A valid PHPcallback $namespace,optional. A string representing a class prefix namespace, or an array of namespace strings.

希望本文所述对大家PHP程序设计有所帮助。

PHP 相关文章推荐
多数据表共用一个页的新闻发布
Oct 09 PHP
在windows iis5下安装php4.0+mysql之我见
Oct 09 PHP
html中select语句读取mysql表中内容
Oct 09 PHP
PHP实现多服务器session共享之NFS共享的方法
Mar 16 PHP
深入理解PHP原理之Session Gc的一个小概率Notice
Apr 12 PHP
php实现文件下载实例分享
Jun 02 PHP
PHP中实现crontab代码分享
Mar 26 PHP
php生成圆角图片的方法
Apr 07 PHP
php自定义hash函数实例
May 05 PHP
PHP Mysqli 常用代码集合
Nov 12 PHP
php利用ob_start()清除输出和选择性输出的方法
Jan 18 PHP
利用PHP内置SERVER开启web服务(本地开发使用)
Jan 22 PHP
Zend Framework教程之Resource Autoloading用法实例
Mar 08 #PHP
php bootstrap实现简单登录
Mar 08 #PHP
PHP Echo字符串的连接格式
Mar 07 #PHP
Zend Framework教程之MVC框架的Controller用法分析
Mar 07 #PHP
Zend Framework教程之路由功能Zend_Controller_Router详解
Mar 07 #PHP
Zend Framework教程之Zend_Controller_Plugin插件用法详解
Mar 07 #PHP
Zend Framework教程之响应对象的封装Zend_Controller_Response实例详解
Mar 07 #PHP
You might like
HTML中嵌入PHP的简单方法
2016/02/16 PHP
thinkPHP显示不出验证码的原因与解决方法分析
2017/05/20 PHP
Laravel 的数据库迁移的方法
2017/07/31 PHP
PHP实现的服务器一致性hash分布算法示例
2018/08/09 PHP
javascript下操作css的float属性的特殊写法
2007/08/22 Javascript
传递参数的标准方法(jQuery.ajax)
2008/11/19 Javascript
jQuery 使用手册(一)
2009/09/23 Javascript
jQuery 连续列表实现代码
2009/12/21 Javascript
ASP.NET jQuery 实例2 (表单中使用回车在TextBox之间向下移动)
2012/01/13 Javascript
解读JavaScript中 For, While与递归的用法
2013/05/07 Javascript
Backbone.js中的集合详解
2015/01/14 Javascript
js图片模糊切换显示特效的方法
2015/02/17 Javascript
Sort()函数的多种用法
2016/03/20 Javascript
jQuery实现在HTML文档加载完毕后自动执行某个事件的方法
2017/05/08 jQuery
从setTimeout看js函数执行过程
2017/12/19 Javascript
Nodejs 识别图片类型的方法
2019/08/15 NodeJs
vant picker+popup 自定义三级联动案例
2020/11/04 Javascript
python使用matplotlib绘制折线图教程
2017/02/08 Python
python进阶_浅谈面向对象进阶
2017/08/17 Python
Python简单生成随机数的方法示例
2018/03/31 Python
pytorch: tensor类型的构建与相互转换实例
2018/07/26 Python
python 实现对文件夹中的图像连续重命名方法
2018/10/25 Python
使用Python+wxpy 找出微信里把你删除的好友实例
2019/02/21 Python
python数据挖掘需要学的内容
2019/06/23 Python
python retrying模块的使用方法详解
2019/09/25 Python
解决pycharm编辑区显示yaml文件层级结构遇中文乱码问题
2020/04/27 Python
keras实现调用自己训练的模型,并去掉全连接层
2020/06/09 Python
python给list排序的简单方法
2020/12/10 Python
HTML5 常用语法一览(列举不支持的属性)
2010/01/26 HTML / CSS
美国隐形眼镜销售网站:ContactsDirect
2017/10/28 全球购物
英国在线购买马术服装:EQUUS
2019/07/12 全球购物
经典优秀毕业生求职信范文分享
2013/12/18 职场文书
校本教研活动总结
2014/07/01 职场文书
营业用房租赁协议书
2014/11/26 职场文书
2015年个人实习工作总结
2014/12/12 职场文书
Minikube搭建Kubernetes集群
2022/03/31 Servers