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 相关文章推荐
PHP 身份证号验证函数
May 07 PHP
PHP的array_diff()函数在处理大数组时的效率问题
Nov 27 PHP
PHP实现多进程并行操作的详解(可做守护进程)
Jun 18 PHP
通过php删除xml文档内容的方法
Jan 23 PHP
基于linnux+phantomjs实现生成图片格式的网页快照
Apr 15 PHP
PHP正则验证Email的方法
Jun 15 PHP
Linux下编译redis和phpredis的方法
Apr 07 PHP
php 数组字符串搜索array_search技巧
Jul 05 PHP
PHP 进度条函数的简单实例
Sep 19 PHP
Laravel学习教程之request validation的编写
Oct 25 PHP
php-fpm添加service服务的例子
Apr 27 PHP
深入学习微信网址链接解封的防封原理visit_type
Aug 15 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
在数据量大(超过10万)的情况下
2007/01/15 PHP
PHP编程过程中需要了解的this,self,parent的区别
2009/12/30 PHP
thinkphp在低版本Nginx 下支持PATHINFO的方法分享
2016/05/27 PHP
什么是PHP7中的孤儿进程与僵尸进程
2019/04/14 PHP
Nigma vs Alliance BO5 第五场2.14
2021/03/10 DOTA
javascript 伪数组实现方法
2010/10/11 Javascript
jquery刷新页面的实现代码(局部及全页面刷新)
2011/07/11 Javascript
javascript全局变量封装模块实现代码
2012/11/28 Javascript
JS打印gridview实现原理及代码
2013/02/05 Javascript
jQuery使用一个按钮控制图片的伸缩实现思路
2013/04/19 Javascript
jquery中push()的用法(数组添加元素)
2014/11/25 Javascript
jQuery事件绑定on()、bind()与delegate() 方法详解
2015/06/03 Javascript
JavaScript数组实现数据结构中的队列与堆栈
2016/05/26 Javascript
由简入繁实现Jquery树状结构的方法(推荐)
2016/06/10 Javascript
jQuery实现订单提交页发送短信功能前端处理方法
2016/07/04 Javascript
jQuery实现对象转为url参数的方法
2017/01/11 Javascript
JS日程管理插件FullCalendar中文说明文档
2017/02/06 Javascript
vue2.0 如何把子组件的数据传给父组件(推荐)
2018/01/15 Javascript
vue源码学习之Object.defineProperty 对数组监听
2018/05/30 Javascript
使用js实现将后台传入的json数据放在前台显示
2018/08/06 Javascript
解决ng-repeat产生的ng-model中取不到值的问题
2018/10/02 Javascript
vue+Vue Router多级侧导航切换路由(页面)的实现代码
2018/12/20 Javascript
javascript原型链学习记录之继承实现方式分析
2019/05/01 Javascript
python str与repr的区别
2013/03/23 Python
Numpy数组的保存与读取方法
2018/04/04 Python
Python实现获取汉字偏旁部首的方法示例【测试可用】
2018/12/18 Python
python 判断字符串中是否含有汉字或非汉字的实例
2019/07/15 Python
Pytorch对Himmelblau函数的优化详解
2020/02/29 Python
python如何变换环境
2020/07/21 Python
基于css3仿造window7的开始菜单
2010/06/17 HTML / CSS
澳大利亚家具和家居用品购物网站:Zanui
2018/12/29 全球购物
小学红领巾中秋节广播稿
2014/01/13 职场文书
新年团拜会主持词
2014/04/02 职场文书
个人对照检查材料思想汇报
2014/09/26 职场文书
2015年班主任个人工作总结
2015/03/31 职场文书
vue3引入highlight.js进行代码高亮的方法实例
2022/04/08 Vue.js