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 相关文章推荐
第十三节 对象串行化 [13]
Oct 09 PHP
PHP 进程锁定问题分析研究
Nov 24 PHP
php join函数应用
May 04 PHP
php cookies中删除的一般赋值方法
May 07 PHP
解析PHP中intval()等int转换时的意外异常情况
Jun 21 PHP
php socket实现的聊天室代码分享
Aug 16 PHP
将FCKeditor导入PHP+SMARTY的实现方法
Jan 15 PHP
PHP中基本HTTP认证技巧分析
Mar 16 PHP
纯php生成随机密码
Oct 30 PHP
yii2中添加验证码的实现方法
Jan 09 PHP
PHP中读取文件的几个方法总结(推荐)
Jun 03 PHP
php分页查询的简单实现代码
Mar 14 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
德生BCL3000的电路分析和打磨
2021/03/02 无线电
PHP模板引擎Smarty的缓存使用总结
2014/04/24 PHP
深入解析PHP中SESSION反序列化机制
2017/03/01 PHP
php引用和拷贝的区别知识点总结
2019/09/23 PHP
js左侧多级菜单动态的解决方案
2010/02/01 Javascript
jQuery焦点图切换特效插件封装实例
2013/08/18 Javascript
nodejs教程之制作一个简单的文章发布系统
2014/11/21 NodeJs
javascript函数特点实例分析
2015/05/14 Javascript
JavaScript数据类型学习笔记
2016/01/25 Javascript
使用pcs api往免费的百度网盘上传下载文件的方法
2016/03/17 Javascript
jQuery实现的省市县三级联动菜单效果完整实例
2016/08/01 Javascript
利用vue.js插入dom节点的方法
2017/03/15 Javascript
Koa2 之文件上传下载的示例代码
2018/03/29 Javascript
layer的prompt弹出框,点击回车,触发确定事件的方法
2019/09/06 Javascript
Vue的transition-group与Virtual Dom Diff算法的使用
2019/12/09 Javascript
[02:32]DOTA2英雄基础教程 祸乱之源
2013/12/23 DOTA
python根据路径导入模块的方法
2014/09/30 Python
python写入xml文件的方法
2015/05/08 Python
利用Python爬取微博数据生成词云图片实例代码
2017/08/31 Python
python cumsum函数的具体使用
2019/07/29 Python
python django model联合主键的例子
2019/08/06 Python
Python爬取智联招聘数据分析师岗位相关信息的方法
2019/08/13 Python
pytorch实现建立自己的数据集(以mnist为例)
2020/01/18 Python
基于Python的OCR实现示例
2020/04/03 Python
Python常用base64 md5 aes des crc32加密解密方法汇总
2020/11/06 Python
python爬虫分布式获取数据的实例方法
2020/11/26 Python
python 利用jieba.analyse进行 关键词提取
2020/12/17 Python
英语专业毕业生求职简历的自我评价
2013/10/24 职场文书
大学生关于奋斗的演讲稿
2014/01/09 职场文书
幼儿园中秋节活动方案
2014/02/06 职场文书
表彰大会主持词
2014/03/26 职场文书
2014年辅导员工作总结
2014/11/18 职场文书
2014年医院党建工作总结
2014/12/20 职场文书
入党积极分子考察意见
2015/06/02 职场文书
辛德勒的名单观后感
2015/06/03 职场文书
SONY AN-LP1 短波有源天线放大器
2021/04/22 无线电