那么指定多个被委托类是不合理的
委托模式是软件设计模式中的一项根基技巧。在委托模式中,有两个东西参预措置惩罚惩罚同一个请求,接受请求的东西将请求委托给另一个东西来措置惩罚惩罚。委托模式是一项根基技巧,许多其他的模式,如状态模式、计谋模式、访谒者模式素质上是在更特殊的场合给与了委托模式。
动态委托的介绍:动态委托观点来自于Jakarta 字节码工程库 (Byte-Code Engineering Library, BCEL)。它能够分析存在的类,并且对付接口,抽象类,甚至运行时的具体类来说,它能够生成以字节编码委托类。
被委托的接口/类应该满足如下条件:动态委托最多只能委托一个类,但是能够代办代理多个接口。这个限制来自于Java的单担任模式。一个Java类最多只有一个父类。既然生成的委托类把被委托类作为它的父类,那么指定多个被委托类是不同理的。如果没有指定被委托类,那么缺省的父类就是Object。
下面是PHP 反射机制实现动态代办代理的代码:
target[] = new Fruit(); } function __call($name, $args) { foreach ($this->target as $obj) { $r = new ReflectionClass($obj); if ($method = $r->getMethod($name)) { if ($method->isPublic() && !$method->isAbstract()) { return $method->invoke($obj, $args); } } } } } $obj = new FruitDelegator(); $obj->callFruit(); // 运行功效 // Generate an Apple ?>
可见,通过代办代理类FruitDelegator来取代Fruit类来实现他的要领。
同样的,如下的代码也是能够运行的:
target[] = $obj; } function __call($name, $args) { foreach ($this->target as $obj) { $r = new ReflectionClass($obj); if ($method = $r->getMethod($name)) { if ($method->isPublic() && !$method->isAbstract()) { return $method->invoke($obj, $args); } } } } } $obj = new ColorDelegator(); $obj->addObject(new Color()); $obj->callColor(); ?>
传统方法:
在传统方法下,我们需要判断当前操纵是取款操纵还是存款操纵,在分袂挪用Bank类中的取款操纵和存款操纵。
委托模式:
在委托模式下,我们将不需要客户真个判断操纵,对客户端来说,需要什么操纵,直接传入操纵类型即可,Bank类可自动判断操纵类型,返回相应操纵的操纵功效。当我们的操纵类型非常多的时候,在客户端用if else判断无疑是很可怕的,,再假如我们在很多处所都要有这块判断代码,我们需要对这些处所的判断代码都进行改削(插手后来添加的判断),而给与委托模式,我们仅仅需要在新添加的处所添加相应需要的类型即可,不需要窜改其它处所的客户端代码(很洪流平上提高了代码的复用性)。
总结
以上就是这篇文章的全部内容了,但愿本文的内容对大家的学习或者事情具有必然的参考学习价值,感谢大家对敏而好学论坛/嗨学网的撑持。如果你想了解更多相关内容请检察下面相关链接
原文地点是:
用PHP的反射实现委托模式的讲解_php技巧 - PHP
温馨提示: 本文由Jm博客推荐,转载请保留链接: https://www.jmwww.net/file/web/33127.html