java:代理模式中实现接口算不算污染?前辈指导下

问题描述

在代理模式中(纯手动,不用InvocationHandler)为了生成代理对象,一般用原对象类抽象出接口,然后原对象类和代理对象类都实现这个接口,这样,可以适用原对象的地方也可以使用代理对象了,然后再在代理对象中加入我们新增的验证之类的功能,大功告成!但是我很好奇 这样对原对象来说算不算污染?因为对于Struts和Struts2或者EJB和Hibernate 就因为多继承了个类或者多实现了个接口,书上就管这个叫做代码污染,或者说影响了扩展性那这样实现的代理模式是不是也是污染了代码呢?还是说为了代码的可扩展性 这些牺牲是微不足道的呢?小弟才疏学浅 叙述疏漏望指正:)

解决方案

添加接口是为了代码的扩展性,这种污染不算是污染,污染是要实现某项功能必须粘合一堆不理解的api,就像struts1中的actionform,使用者不理解为什么要写个servlet就必须用这个api,而这个接口你是理解的,是一个扩展接口。如果spring每次配置一个bean都必须让那个bean继承某个BaseBean,那就是一种污染。污染更多的来自与继承,而非接口与组合。
解决方案二:
首先,你得明白什么是接口污染的定义,那就是在一个实现类中,实现了与业务无关的方法,而此方法仅仅是一个必要实现,为了不报错嘛,这个对于系统来说是非常危险的事,假如用户不小心使用了此方法,带来的后果是不可预测的,对于更小粒度的实现来说,为了不造成接口污染,在6大设计原则里面有明确的接口分离原则,目的就是为了避免接口污染,你可以再考虑下你的模式,思考下是否有接口污染的冲突存在,谢谢!
解决方案三:
我觉得只要每个接口的粒度合适(方法个数控制在一定范围之内),具体类所实现的接口个数适当(取决于业务的复杂程度和具体类的职责),就不存在污染不污染,设计本身就是寻找一种平衡,简单明了就好。

时间: 2024-11-28 18:00:06

java:代理模式中实现接口算不算污染?前辈指导下的相关文章

Java代理模式详解

代理是一种常用的设计模式,其目的就是为其他对象提供一个代理以控制对某个对象的访问.代理类负责为委托类预处理消息,过滤消息并转发消息,以及进行消息被为拖累执行后的后续处理. 为了保持行为的一致性,代理类和委托类通常会实现相同的接口,所以在访问者看来两者没有丝毫的区别.通过代理类这中间一层,能有效控制对委托类对象的直接访问,也可以很好地隐藏和保护委托类对象,同时也为实施不同控制策略预留了空间,从而在设计上获得了更大的灵活性. 更通俗的说,代理解决的问题当两个类需要通信时,引入第三方代理类,将两个类的

Java代理模式

一.Java代理模式 代理是一种常用的设计模式,其目的就是为其他对象提供一个代理以控制对某个对象的访问.代理类负责为委托类预处理消息,过滤消息并转发消息,以及进行消息被委托类执行后的后续处理. 代理模式结构图 为了保持行为的一致性,代理类和委托类通常会实现相同的接口,所以在访问者看来两者没有丝毫的区别.通过代理类这中间一层,能有效控制对委托类对象的直接访问,也可以很好地隐藏和保护委托类对象,同时也为实施不同控制策略预留了空间,从而在设计上获得了更大的灵活性. 更通俗的说,代理解决的问题当两个类需

java代理模式与动态代理模式详解_java

1.代理模式 所谓代理,就是一个人或者一个机构代表另一个人或者另一个机构采取行动.在一些情况下,一个客户不想或者不能够直接引用一个对象,而代理对象可以在客户端和目标对象之前起到中介的作用.代理模式给某一个对象提供一个代理对象,并由代理对象控制对原对象的引用. 生活中的例子:过年加班比较忙,没空去买火车票,这时可以打个电话到附近的票务中心,叫他们帮你买张回家的火车票,当然这会附加额外的劳务费.但要清楚票务中心自己并不卖票,只有火车站才真正卖票,票务中心卖给你的票其实是通过火车站实现的.这点很重要!

轻松掌握Java代理模式_java

和大家一起聊一聊java代理模式 1.静态代理 1.1静态代理的代理类和和被代理的类都要维护一个共同的接口.  public interface IUserDao { void save(); } 1.2被代理的类,目标对象  public class UserDao implements IUserDao{ @Override public void save() { System.out.println("-----已经保存数据!!!------"); } } 1.3代理对象  p

java代理模式与反射机制

代理模式的作用是:为其他对象提供一种代理以控制对这个对象的访问.在某些情况下,一个客户不想或者不能直接引用另一个对象,而代理对象可以在客户端和目标对象之间起到中介的作用.  代理模式一般涉及到的角色有:  抽象角色:声明真实对象和代理对象的共同接口:  代理角色:代理对象角色内部含有对真实对象的引用,从而可以操作真实对象,同时代理对象提供与真实对象相同的接口以便在任何时刻都能代替真实对象.同时,代理对象可以在执行真实对象操作时,附加其他的操作,相当于对真实对象进行封装.  真实角色:代理角色所代

Java和C#中的接口对比(有你不知道的东西)

1.与Java不同,C#中的接口不能包含字段(Field). 在java中,接口中可以包含字段,但是这些字段隐式地是static和final的.而C#不允许接口中有字段,编译器在编译时就会提示错误(如下代码所示). interface IInterface { int a ;//编译器错误提示:接口不能包含字段 } 2.在C#和Java中,接口内的所有方法默认都是公用方法. 在Java中,方法声明可以带有public修饰符(即使这并非必要),但在C#中,显式地为接口中的方法指定public修饰符

举例说明Java设计模式编程中ISP接口隔离原则的使用_java

Interface Segregation Principle,ISP接口隔离原则主张使用多个专门的接口比使用单一的总接口要好. 一个类对另外一个类的依赖性应当是建立在最小的接口上的. 一个接口代表一个角色,不应当将不同的角色都交给一个接口.没有关系的接口合并在一起,形成一个臃肿的大接口,这是对角色和接口的污染. "不应该强迫客户依赖于它们不用的方法.接口属于客户,不属于它所在的类层次结构."这个说得很明白了,再通俗点说,不要强迫客户使用它们不用的方法,如果强迫用户使用它们不使用的方法

java 代理模式(静态代理+动态代理)

静态代理: ISubject: /** * @author com.tiantian * @version 创建时间:2012-11-20 下午1:49:29 */ public interface ISubject { public void request(); } RealSubject(真实角色): /** * @author com.tiantian * @version 创建时间:2012-11-20 下午1:51:37 */ public class RealSubject imp

Java使用设计模式中的代理模式构建项目的实例展示_java

概念 代理模式(Proxy):代理模式其实就是多一个代理类出来,替原对象进行一些操作.比如咱有的时候打官司需要请律师,因为律师在法律方面有专长,可以替咱进行操作表达咱的想法,这就是代理的意思.代理模式分为两类:1.静态代理(不使用jdk里面的方法):2.动态代理(使用jdk里面的InvocationHandler和Proxy). 静态代理由程序员创建或工具生成代理类的源码,再编译代理类.所谓静态也就是在程序运行前就已经存在代理类的字节码文件,代理类和委托类的关系在运行前就确定了. 动态代理类的源