欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  后端开发

PHP设计模式漫谈之解释器模式_PHP

程序员文章站 2022-05-14 22:58:05
...
PHP设计模式漫谈系列已经连载的四周,我们了解了PHP设计模式中的代理模式、责任链模式、结构模式命令模式。我们今天的主角是解释器(Interpreter)模式,它包括一个具有复合类分层结构的文法表现,规则是映射到类,跟随在文法后面的表达式可以被转换成一个抽象的语法树,除了复合模式的实例对象图外,没有别的内容。

欲了解更多关于PHP设计模式的内容,欢迎访问:PHP设计模式漫谈

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

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

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

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

参与者:

◆客户端(Client):使用解释操作。

◆抽象表达式(AbstractExpression):基于一个表达式树抽象。

◆非终结符表达式(NonTerminalExpression):递归地包含其它抽象表达式(AbstractExpression实例)的表达式。

◆终结符表达式(TerminalExpression):不能够进一步简化的表达式。

PHP设计模式漫谈之解释器模式_PHP
解释器模式示例

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

  1. /**
  2. * AbstractExpression. All implementations of this interface
  3. * are ConcreteExpressions.
  4. */
  5. interface MathExpression
  6. {
  7. /**
  8. * Calculates the value assumed by the expression.
  9. * Note that $values is passed to all expression but it
  10. * is used by Variable only. This is required to abstract
  11. * away the tree structure.
  12. */
  13. public function evaluate(array $values);
  14. }
  15. /**
  16. * A terminal expression which is a literal value.
  17. */
  18. class Literal implements MathExpression
  19. {
  20. private PHP设计模式漫谈系列已经连载的四周,我们了解了PHP设计模式中的代理模式、责任链模式、结构模式命令模式。我们今天的主角是解释器(Interpreter)模式,它包括一个具有复合类分层结构的文法表现,规则是映射到类,跟随在文法后面的表达式可以被转换成一个抽象的语法树,除了复合模式的实例对象图外,没有别的内容。

    欲了解更多关于PHP设计模式的内容,欢迎访问:PHP设计模式漫谈

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

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

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

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

    参与者:

    ◆客户端(Client):使用解释操作。

    ◆抽象表达式(AbstractExpression):基于一个表达式树抽象。

    ◆非终结符表达式(NonTerminalExpression):递归地包含其它抽象表达式(AbstractExpression实例)的表达式。

    ◆终结符表达式(TerminalExpression):不能够进一步简化的表达式。

    PHP设计模式漫谈之解释器模式_PHP
    解释器模式示例

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

    ___FCKpd___0

    我们会在下周继续为您连载PHP设计模式漫谈系列文章,敬请期待。

    value
    ;
  21. public function __construct($value)
  22. {
  23. $this->_value = $value;
  24. }
  25. public function evaluate(array $values)
  26. {
  27. return $this->_value;
  28. }
  29. }
  30. /**
  31. * A terminal expression which represents a variable.
  32. */
  33. class Variable implements MathExpression
  34. {
  35. private PHP设计模式漫谈系列已经连载的四周,我们了解了PHP设计模式中的代理模式、责任链模式、结构模式命令模式。我们今天的主角是解释器(Interpreter)模式,它包括一个具有复合类分层结构的文法表现,规则是映射到类,跟随在文法后面的表达式可以被转换成一个抽象的语法树,除了复合模式的实例对象图外,没有别的内容。

    欲了解更多关于PHP设计模式的内容,欢迎访问:PHP设计模式漫谈

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

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

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

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

    参与者:

    ◆客户端(Client):使用解释操作。

    ◆抽象表达式(AbstractExpression):基于一个表达式树抽象。

    ◆非终结符表达式(NonTerminalExpression):递归地包含其它抽象表达式(AbstractExpression实例)的表达式。

    ◆终结符表达式(TerminalExpression):不能够进一步简化的表达式。

    PHP设计模式漫谈之解释器模式_PHP
    解释器模式示例

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

    ___FCKpd___0

    我们会在下周继续为您连载PHP设计模式漫谈系列文章,敬请期待。

    letter
    ;
  36. public function __construct($letter)
  37. {
  38. $this->_letter = $letter;
  39. }
  40. public function evaluate(array $values)
  41. {
  42. return $values[$this->_letter];
  43. }
  44. }
  45. /**
  46. * Nonterminal expression.
  47. */
  48. class Sum implements MathExpression
  49. {
  50. private PHP设计模式漫谈系列已经连载的四周,我们了解了PHP设计模式中的代理模式、责任链模式、结构模式命令模式。我们今天的主角是解释器(Interpreter)模式,它包括一个具有复合类分层结构的文法表现,规则是映射到类,跟随在文法后面的表达式可以被转换成一个抽象的语法树,除了复合模式的实例对象图外,没有别的内容。

    欲了解更多关于PHP设计模式的内容,欢迎访问:PHP设计模式漫谈

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

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

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

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

    参与者:

    ◆客户端(Client):使用解释操作。

    ◆抽象表达式(AbstractExpression):基于一个表达式树抽象。

    ◆非终结符表达式(NonTerminalExpression):递归地包含其它抽象表达式(AbstractExpression实例)的表达式。

    ◆终结符表达式(TerminalExpression):不能够进一步简化的表达式。

    PHP设计模式漫谈之解释器模式_PHP
    解释器模式示例

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

    ___FCKpd___0

    我们会在下周继续为您连载PHP设计模式漫谈系列文章,敬请期待。

    a
    ;
  51. private PHP设计模式漫谈系列已经连载的四周,我们了解了PHP设计模式中的代理模式、责任链模式、结构模式命令模式。我们今天的主角是解释器(Interpreter)模式,它包括一个具有复合类分层结构的文法表现,规则是映射到类,跟随在文法后面的表达式可以被转换成一个抽象的语法树,除了复合模式的实例对象图外,没有别的内容。

    欲了解更多关于PHP设计模式的内容,欢迎访问:PHP设计模式漫谈

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

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

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

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

    参与者:

    ◆客户端(Client):使用解释操作。

    ◆抽象表达式(AbstractExpression):基于一个表达式树抽象。

    ◆非终结符表达式(NonTerminalExpression):递归地包含其它抽象表达式(AbstractExpression实例)的表达式。

    ◆终结符表达式(TerminalExpression):不能够进一步简化的表达式。

    PHP设计模式漫谈之解释器模式_PHP
    解释器模式示例

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

    ___FCKpd___0

    我们会在下周继续为您连载PHP设计模式漫谈系列文章,敬请期待。

    b
    ;
  52. public function __construct(MathExpression $a, MathExpression $b)
  53. {
  54. $this->_a = $a;
  55. $this->_b = $b;
  56. }
  57. public function evaluate(array $values)
  58. {
  59. return $this->_a->evaluate($values) + $this->_b->evaluate($values);
  60. }
  61. }
  62. /**
  63. * Nonterminal expression.
  64. */
  65. class Product implements MathExpression
  66. {
  67. private PHP设计模式漫谈系列已经连载的四周,我们了解了PHP设计模式中的代理模式、责任链模式、结构模式命令模式。我们今天的主角是解释器(Interpreter)模式,它包括一个具有复合类分层结构的文法表现,规则是映射到类,跟随在文法后面的表达式可以被转换成一个抽象的语法树,除了复合模式的实例对象图外,没有别的内容。

    欲了解更多关于PHP设计模式的内容,欢迎访问:PHP设计模式漫谈

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

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

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

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

    参与者:

    ◆客户端(Client):使用解释操作。

    ◆抽象表达式(AbstractExpression):基于一个表达式树抽象。

    ◆非终结符表达式(NonTerminalExpression):递归地包含其它抽象表达式(AbstractExpression实例)的表达式。

    ◆终结符表达式(TerminalExpression):不能够进一步简化的表达式。

    PHP设计模式漫谈之解释器模式_PHP
    解释器模式示例

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

    ___FCKpd___0

    我们会在下周继续为您连载PHP设计模式漫谈系列文章,敬请期待。

    a
    ;
  68. private PHP设计模式漫谈系列已经连载的四周,我们了解了PHP设计模式中的代理模式、责任链模式、结构模式命令模式。我们今天的主角是解释器(Interpreter)模式,它包括一个具有复合类分层结构的文法表现,规则是映射到类,跟随在文法后面的表达式可以被转换成一个抽象的语法树,除了复合模式的实例对象图外,没有别的内容。

    欲了解更多关于PHP设计模式的内容,欢迎访问:PHP设计模式漫谈

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

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

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

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

    参与者:

    ◆客户端(Client):使用解释操作。

    ◆抽象表达式(AbstractExpression):基于一个表达式树抽象。

    ◆非终结符表达式(NonTerminalExpression):递归地包含其它抽象表达式(AbstractExpression实例)的表达式。

    ◆终结符表达式(TerminalExpression):不能够进一步简化的表达式。

    PHP设计模式漫谈之解释器模式_PHP
    解释器模式示例

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

    ___FCKpd___0

    我们会在下周继续为您连载PHP设计模式漫谈系列文章,敬请期待。

    b
    ;
  69. public function __construct(MathExpression $a, MathExpression $b)
  70. {
  71. $this->_a = $a;
  72. $this->_b = $b;
  73. }
  74. public function evaluate(array $values)
  75. {
  76. return $this->_a->evaluate($values) * $this->_b->evaluate($values);
  77. }
  78. }
  79. // 10(a + 3)
  80. $expression = new Product(new Literal(10), new Sum(new Variable('a'), new Literal(3)));
  81. echo $expression->evaluate(array('a' => 4)), "\n";
  82. // adding new rules to the grammar is easy:
  83. // e.g. Power, Subtraction...
  84. // thanks to the Composite, manipulation is even simpler:
  85. // we could add substitute($letter, MathExpression $expr)
  86. // to the interface...

我们会在下周继续为您连载PHP设计模式漫谈系列文章,敬请期待。