[size=large]
设计模式3
适配器模式
适配器模式就是将两个不兼容的类纠合在一起使用,它需要有被适配者和适配器两个身份,由于适配器类是源的一个子类,因此可以在适配器中置换掉源的一些方法。
例如windows操作系统中的快捷方式,其实就是一个适配器的例子。
下面关于适配器模式的应用
先定义一个接口
Public interface Operation{
Public void Activated();
Public void closing();
Public void deactivated();
Public void deiconified();
Public void iconified();
Public void opened();
}
Operation 类为被适配者,在这个接口中声明了多个方法,每个方法提供不同的功能;当我们需要实现这个类的时候、必须全部实现这个接口中的全部方法。对于使用者而言如果实现Operation接口中的某个或某几个方法时,其他的方法也必须同时给出实现。
Public abstract class Adapter implements Operation{
Public void Activated(){}
Public void closed(){}
Public void closing(){}
Public void deactivated(){}
Public void deiconified(){}
Public void incoified(){}
Public void iconified(){}
Public void opened(){}
}
Adapter 类实现了operation接口,在adapter类中、给出了operation接口中的全部方法实现;给出这些实现后、我们可以认为是adaptor对operation进行了适配 ,这个适配体现在当客户端需要给出某个具体的方法实现时、可以不必理会无关的方法;让实现变得更为轻便。这一点在匿名内部类中体现得非常明显。
应用时、调用具体的方法就好了
Adaptor adaptor = new Adaptor(){
Public void closing(){}
}
代理模式
所谓代理、就是一个人或一个机构代表另一个人或另一个机构采取行动;而代理对象可以在客户端和目标对象之间起到中介的作用。
代理模式是给某一个对象提供一个代理对象,并由代理对象控制原对象的引用。
应用:
先定义一个抽象类
Public abstract class Subject{
Public abstract void deleteSubject();
}
然后在继承类中实现具体方法
Public class RealSubject extends Subject{
Public abstract void deleteSubject(){
//具体的实现方法
}
}
由于deleteSubject操作的敏感性,如果需要在执行这个方法之前执行一些前处理和后处理的工作如权限过滤等;那就要在真实主题RealSubject被访问之前、执行一些代理操作;而代理类就负责执行这一过程。
Public class ProxySubject extends Subject{
RealSubject realsubject;
Public void deleteSubject(){
//前处理方法
If(!validatePermission()){
Throws new Runtime Exception(“对不起、你没有此权限”);
}
realsubject.deleteSubject();
//后处理方法
Clear();
}
}
在ProxySubject类中,直接继承了Subject抽象类、同RealSubject类一样;ProxySubject需要实现Subject中的方法deleteSubject();由于需要对RealSubject进行一些代理操作;在ProxySubject类中的deleteSubject()方法中,直接调用了RealSubject类中的deleteSubject()方法。并在这个方法执行前、进行了验证。
[/size]
设计模式3
适配器模式
适配器模式就是将两个不兼容的类纠合在一起使用,它需要有被适配者和适配器两个身份,由于适配器类是源的一个子类,因此可以在适配器中置换掉源的一些方法。
例如windows操作系统中的快捷方式,其实就是一个适配器的例子。
下面关于适配器模式的应用
先定义一个接口
Public interface Operation{
Public void Activated();
Public void closing();
Public void deactivated();
Public void deiconified();
Public void iconified();
Public void opened();
}
Operation 类为被适配者,在这个接口中声明了多个方法,每个方法提供不同的功能;当我们需要实现这个类的时候、必须全部实现这个接口中的全部方法。对于使用者而言如果实现Operation接口中的某个或某几个方法时,其他的方法也必须同时给出实现。
Public abstract class Adapter implements Operation{
Public void Activated(){}
Public void closed(){}
Public void closing(){}
Public void deactivated(){}
Public void deiconified(){}
Public void incoified(){}
Public void iconified(){}
Public void opened(){}
}
Adapter 类实现了operation接口,在adapter类中、给出了operation接口中的全部方法实现;给出这些实现后、我们可以认为是adaptor对operation进行了适配 ,这个适配体现在当客户端需要给出某个具体的方法实现时、可以不必理会无关的方法;让实现变得更为轻便。这一点在匿名内部类中体现得非常明显。
应用时、调用具体的方法就好了
Adaptor adaptor = new Adaptor(){
Public void closing(){}
}
代理模式
所谓代理、就是一个人或一个机构代表另一个人或另一个机构采取行动;而代理对象可以在客户端和目标对象之间起到中介的作用。
代理模式是给某一个对象提供一个代理对象,并由代理对象控制原对象的引用。
应用:
先定义一个抽象类
Public abstract class Subject{
Public abstract void deleteSubject();
}
然后在继承类中实现具体方法
Public class RealSubject extends Subject{
Public abstract void deleteSubject(){
//具体的实现方法
}
}
由于deleteSubject操作的敏感性,如果需要在执行这个方法之前执行一些前处理和后处理的工作如权限过滤等;那就要在真实主题RealSubject被访问之前、执行一些代理操作;而代理类就负责执行这一过程。
Public class ProxySubject extends Subject{
RealSubject realsubject;
Public void deleteSubject(){
//前处理方法
If(!validatePermission()){
Throws new Runtime Exception(“对不起、你没有此权限”);
}
realsubject.deleteSubject();
//后处理方法
Clear();
}
}
在ProxySubject类中,直接继承了Subject抽象类、同RealSubject类一样;ProxySubject需要实现Subject中的方法deleteSubject();由于需要对RealSubject进行一些代理操作;在ProxySubject类中的deleteSubject()方法中,直接调用了RealSubject类中的deleteSubject()方法。并在这个方法执行前、进行了验证。
[/size]