打字猴:1.70045365e+09
1700453650 public void doStuff(HashMap map){
1700453651
1700453652 }
1700453653
1700453654 }
1700453655
1700453656 class Sub extends Base{
1700453657
1700453658 public void doStuff(Map map){
1700453659
1700453660 }
1700453661
1700453662 }
1700453663
1700453664 这是Java的重载实现,子类型在实现父类型的同时也具备了自己的个性,可以处理比父类型更宽泛的任务,而且不会影响父类的任何行为,例如在如下代码中把父类型替换为子类型就不会有任何变化:
1700453665
1700453666 public static void main(String[]args){
1700453667
1700453668 Base b=new Base();
1700453669
1700453670 b.doStuff(new HashMap());
1700453671
1700453672 }
1700453673
1700453674 此时,把Base全部替换为Sub,所有的行为全部还是由父类型Base实现的,子类型的doStuff方法并没有调用,也就是说,子类型可以在扩展前置条件的情况下保持类的可替换性。
1700453675
1700453676 (3)后置条件可以被缩小
1700453677
1700453678 父类型方法的返回值是类型T,子类同名方法(重载或覆写)的返回值为S,那么S可以是T的子集,这里又分为两种情况:
1700453679
1700453680 若是覆写,父类型和子类型的方法名名称就会相同,输入参数也相同(前置条件相同),只是返回值S是T类型的子集,子类型替换父类型完全没有问题。
1700453681
1700453682 若是重载,方法的输入参数类型或数量则不相同(前置条件不同),在使用子类型替换父类型的情况下,子类型的方法不会被调用到的,已经无关返回值类型了,此时子类依然具备可替换性。
1700453683
1700453684 增强类的可替换性,则增强了程序的健壮性,版本升级时也可以保持非常好的兼容性。即使增加子类,原有的子类还可以继续运行。在实际项目中,每个子类对应不同的业务含义,使用父类作为参数,传递不同的子类完成不同的业务逻辑,非常完美!
1700453685
1700453686
1700453687
1700453688
1700453689 编写高质量代码:改善Java程序的151个建议 [:1700438227]
1700453690 编写高质量代码:改善Java程序的151个建议 建议149:依赖抽象而不是实现
1700453691
1700453692 在面向过程开发中,我们考虑的是如何实现,依赖的是每个具体实现,而在OOP中,则需要依赖每个接口,而不能依赖具体的实现,比如我们要到北京出差,应该依赖交通工具,而不是依赖的具体飞机或火车,也就是说我们依赖的是交通工具的运输能力,而不是具体的一架飞机或某一列火车。这样的依赖可以让我们实现解耦,保持代码间的松耦合,提高代码的复用率,这也是依赖倒置原则(Dependence Inversion Principle,简称DIP)提出的要求。
1700453693
1700453694 依赖倒置原则的原始定义是:High level modules should not depend upon low level modules.Both should depend upon abstractions.Abstractions should not depend upon details.Details should depend upon abstractions。翻译过来,包含三层含义:
1700453695
1700453696 高层模块不应该依赖低层模块,两者都应该依赖其抽象。
1700453697
1700453698 抽象不应该依赖细节。
1700453699
[ 上一页 ]  [ :1.70045365e+09 ]  [ 下一页 ]