PHP设计模式之解释器模式的深入解析


Posted in PHP onJune 13, 2013

解释器(Interpreter)模式,它包括一个具有复合类分层结构的文法表现,规则是映射到类,跟随在文法后面的表达式可以被转换成一个抽象的语法树,除了复合模式的实例对象图外,没有别的内容。

树是一个抽象的名词,因为实际上大多数时候它是一个表达式的抽象表现,它忽略了可能有一个字符串,也可能有一个数据结构的具体表达式,(例如,在PHP中,“A”和“\x41”是相同抽象字面值的不同具体表现),通过逻辑规则解耦结果,使解释过程大大简化。

解释器不是一个很常见的模式,但对于简单的语法,它添加一个规则就象添加一个类那样容易,但它没有解决从具体表现形式到抽象语法树的转换,这是由其它服务完成的。

解释器模式旨在为一个简单的抽象表达式(AbstractExpression)方法(解释器操作)实现利用复合分层结构,解释器操作的参数通常统称为上下文,对于给定的一个方法,它们通常被计算值代替,或它们对某些操作可能不存在。

同样,当包含一个解释器时,复合模式的叶子和容器参与者名称会不一样,这些名称反映了它们所扮演的角色:终结符(terminal)或非终结符(nonterminal)表达式。

参与者:
◆客户端(Client):使用解释操作。
◆抽象表达式(AbstractExpression):基于一个表达式树抽象。
◆非终结符表达式(NonTerminalExpression):递归地包含其它抽象表达式(AbstractExpression实例)的表达式。
◆终结符表达式(TerminalExpression):不能够进一步简化的表达式。
PHP设计模式之解释器模式的深入解析

《设计模式》一书针对这个模式提供了一个扩展示例,我将使用数学表达式替换布尔表达式重新改造了一下,因此这个例子解决了一个数学表达式的展现,它的evaluate( )被分离在一个不同的ConcreteExpression类中。

/**  
 * AbstractExpression. All implementations of this interface  
 * are ConcreteExpressions.  
 */ 
interface MathExpression  
{  
    /**  
     * Calculates the value assumed by the expression.  
     * Note that $values is passed to all expression but it  
     * is used by Variable only. This is required to abstract  
     * away the tree structure.  
     */ 
    public function evaluate(array $values);  
}  /**  
 * A terminal expression which is a literal value.  
 */ 
class Literal implements MathExpression  
{  
    private $_value;  
    public function __construct($value)  
    {  
        $this->_value = $value;  
    }  
    public function evaluate(array $values)  
    {  
        return $this->_value;  
    }  
}  
/**  
 * A terminal expression which represents a variable.  
 */ 
class Variable implements MathExpression  
{  
    private $_letter;  
    public function __construct($letter)  
    {  
        $this->_letter = $letter;  
    }  
    public function evaluate(array $values)  
    {  
        return $values[$this->_letter];  
    }  
}  
/**  
 * Nonterminal expression.  
 */ 
class Sum implements MathExpression  
{  
    private $_a;  
    private $_b;  
    public function __construct(MathExpression $a, MathExpression $b)  
    {  
        $this->_a = $a;  
        $this->_b = $b;  
    }  
    public function evaluate(array $values)  
    {  
        return $this->_a->evaluate($values) + $this->_b->evaluate($values);  
    }  
}  
/**  
 * Nonterminal expression.  
 */ 
class Product implements MathExpression  
{  
    private $_a;  
    private $_b;  
    public function __construct(MathExpression $a, MathExpression $b)  
    {  
        $this->_a = $a;  
        $this->_b = $b;  
    }  
    public function evaluate(array $values)  
    {  
        return $this->_a->evaluate($values) * $this->_b->evaluate($values);  
    }  
}  
// 10(a + 3)  
$expression = new Product(new Literal(10), new Sum(new Variable('a'), new Literal(3)));  
echo $expression->evaluate(array('a' => 4)), "\n";  
// adding new rules to the grammar is easy:  
// e.g. Power, Subtraction...  
// thanks to the Composite, manipulation is even simpler:  
// we could add substitute($letter, MathExpression $expr)  
// to the interface...
PHP 相关文章推荐
一个用于mysql的数据库抽象层函数库
Oct 09 PHP
php 字符串函数收集
Mar 29 PHP
PHP及Zend Engine的线程安全模型分析
Nov 10 PHP
PHP 处理TXT文件(打开/关闭/检查/读取)
May 13 PHP
php文件夹与文件目录操作函数介绍
Sep 09 PHP
PHP 实现的将图片转换为TXT
Oct 21 PHP
使用PHP实现下载CSS文件中的图片
Dec 06 PHP
php5.4传引用时报错问题分析
Jan 22 PHP
PHP实现原比例生成缩略图的方法
Feb 03 PHP
PHP类型约束用法示例
Sep 28 PHP
PHP+JQUERY操作JSON实例
Mar 23 PHP
在PHP中实现使用Guzzle执行POST和GET请求
Oct 15 PHP
PHP设计模式之代理模式的深入解析
Jun 13 #PHP
PHP设计模式之责任链模式的深入解析
Jun 13 #PHP
PHP设计模式之结构模式的深入解析
Jun 13 #PHP
PHP设计模式之命令模式的深入解析
Jun 13 #PHP
深入Memcache的Session数据的多服务器共享详解
Jun 13 #PHP
探讨:如何使用PHP实现计算两个日期间隔的年、月、周、日数
Jun 13 #PHP
判断php数组是否为索引数组的实现方法
Jun 13 #PHP
You might like
用PHP和ACCESS写聊天室(三)
2006/10/09 PHP
Ajax+PHP边学边练 之五 图片处理
2009/12/03 PHP
php数据类型判断函数有哪些
2013/09/23 PHP
使用图灵api创建微信聊天机器人
2015/07/23 PHP
ThinkPHP删除栏目(实现批量删除栏目)
2017/06/21 PHP
PHP中的empty、isset、isnull的区别与使用实例
2019/03/22 PHP
对google个性主页的拖拽效果的js的完整注释[转]
2007/04/10 Javascript
excel操作之Add Data to a Spreadsheet Cell
2007/06/12 Javascript
js 替换
2008/02/19 Javascript
基于jquery的无刷新分页技术
2011/06/11 Javascript
javascript调试之DOM断点调试法使用技巧分享
2014/04/15 Javascript
js中各种类型的变量在if条件中是true还是false
2014/07/16 Javascript
在Mac OS下使用Node.js的简单教程
2015/06/24 Javascript
深入学习jQuery Validate表单验证(二)
2016/01/18 Javascript
JavaScript蒙板(model)功能的简单实现代码
2016/08/04 Javascript
vue+node实现图片上传及预览的示例方法
2018/11/22 Javascript
微信小程序性能优化之checkSession的使用
2019/03/06 Javascript
如何让Nodejs支持H5 History模式(connect-history-api-fallback源码分析)
2019/05/30 NodeJs
Vue 实现一个命令式弹窗组件功能
2019/09/25 Javascript
vue 路由子组件created和mounted不起作用的解决方法
2019/11/05 Javascript
通过实例解析jQ Ajax操作相关原理
2020/09/23 Javascript
详解vue实现坐标拾取器功能示例
2020/11/18 Vue.js
[01:07:46]完美世界DOTA2联赛循环赛 Magma vs IO BO2第二场 11.01
2020/11/02 DOTA
python检测服务器是否正常
2014/02/16 Python
[原创]Python入门教程4. 元组基本操作
2018/10/31 Python
Python理解递归的方法总结
2019/01/28 Python
Python3 批量扫描端口的例子
2019/07/25 Python
opencv-python 提取sift特征并匹配的实例
2019/12/09 Python
Django-xadmin+rule对象级权限的实现方式
2020/03/30 Python
python爬虫调度器用法及实例代码
2020/11/30 Python
Python wordcloud库安装方法总结
2020/12/31 Python
请解释一下webService? 如何用.net实现webService
2014/06/09 面试题
市政施工员自我鉴定
2014/01/15 职场文书
美术教师自我鉴定
2014/02/12 职场文书
企业安全生产规章制度
2015/08/06 职场文书
2016年庆祝六一儿童节活动总结
2016/04/06 职场文书