delegation模式

王朝other·作者佚名  2006-01-09
宽屏版  字体: |||超大  

2004-10-28撰写

读Globus Toolkit编程文档时,里面在实现operation provider时提到了delegation模式。

GOF的设计模式里好像没有这个模式,还好网上找到了相关的文档。翻译如下:

委托模式:(应该翻译成委托吧,如果翻译成代理容易和proxy模式混淆)

委托模式是一种技术,一个对象在外界来看好像实现了一些行为,但实际上是委托给相关的其他类来实现行为的.在不可以使用继承,而采用聚合时,必须使用这种技术.

一个简单的java例子:

这个例子中,C拥有调用A中f()和g()的插口.看起来C好像有A的功能.

class A {

void f() { system.out.println("A: doing f()"; }

void g() { system.out.println("A: doing g()"; }

}

class C {

// delegation

A a = new A();

void f() { a.f(); }

void g() { a.g(); }

// normal attributes

X x = new X();

void y() { /* do stuff */ }

}

void main() {

C c = new C();

c.f();

c.g();

}

另一个复杂些的java例子.

使用接口+委托可以提高程序灵活性,和类型的安全性.这个例子中,C代理了A,B二者之一.C可以在A,B之间切换.由于A,B都必须通过实现接口以实现功能,这就提高了了类型安全性.作为折中,当然也需要写更多的代码.

interface I {

void f();

void g();

}

class A implements I {

void f() { system.out.println("A: doing f()"; }

void g() { system.out.println("A: doing g()"; }

}

class B implements I {

void f() { system.out.println("B: doing f()"; }

void g() { system.out.println("B: doing g()"; }

}

class C implements I {

// delegation

I i = new A();

void f() { i.f(); }

void g() { i.g(); }

// normal attributes

void toA() { i = new A(); }

void toB() { i = new B(); }

}

void main() {

C c = new C();

c.f();

c.g();

}

缺点:这个模式是典型的牺牲性能提高抽象程序的清晰程度. (或者说提高代码可读性)

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
© 2005- 王朝网络 版权所有