target[] = new ClassOne(); } 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 ClassOneDelegator();$obj->callClassOne();?>
输出结果:
In Class One
可见,通过代理类ClassOneDelegator来代替ClassOne类来实现他的方法。
同样的,如下的代码也是能够运行的:
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 ClassOneDelegator();$obj->addObject(new ClassOne());$obj->callClassOne();?>
什是PHP的反射机制
也可以叫映射。说直白点,他不仅能克隆到对象,而且可以调用对象的变量甚
至方法,挺强大的。php API5关于与对象有解释,有机会可以看下,类似于
java中的。当然,这种特性,足以证明php与asp还是有很大区别的!
JAVA的反射机制的原理是什 最好还可以带上个怎使用反射机制的例子
Field[] fields = object.getClass().getDeclaredFields();
for (int j = 0; j < fields.length; j++) {
try {
Method method = object.getClass().getMethod(“get” + name.substring(0, 1).toUpperCase()
+ name.substring(1), new Class[] {});
Object result = method.invoke(object, new Object[] {});
} catch (Exception e) {
e.getStackTrace();
}
}