打字猴:1.70043861e+09
1700438610
1700438611 对于client.methodA(“china”,null)方法,直接量null是没有类型的,虽然两个methodA方法都符合调用请求,但不知道调用哪一个,于是报错了。我们来体会一下它的坏味道:除了不符合上面的懒人原则外,这里还有一个非常不好的编码习惯,即调用者隐藏了实参类型,这是非常危险的,不仅仅调用者需要“猜测”该调用哪个方法,而且被调用者也可能产生内部逻辑混乱的情况。对于本例来说应该做如下修改:
1700438612
1700438613 public static void main(String[]args){
1700438614
1700438615 Client client=new Client();
1700438616
1700438617 String[]strs=null;
1700438618
1700438619 client.methodA(“China”,strs);
1700438620
1700438621 }
1700438622
1700438623 也就是说让编译器知道这个null值是String类型的,编译即可顺利通过,也就减少了错误的发生。
1700438624
1700438625
1700438626
1700438627
1700438628 编写高质量代码:改善Java程序的151个建议 [:1700438073]
1700438629 编写高质量代码:改善Java程序的151个建议 建议6:覆写变长方法也循规蹈矩
1700438630
1700438631 在Java中,子类覆写父类中的方法很常见,这样做既可以修正Bug也可以提供扩展的业务功能支持,同时还符合开闭原则(Open-Closed Principle),我们来看一下覆写必须满足的条件:
1700438632
1700438633 重写方法不能缩小访问权限。
1700438634
1700438635 参数列表必须与被重写方法相同。
1700438636
1700438637 返回类型必须与被重写方法的相同或是其子类。
1700438638
1700438639 重写方法不能抛出新的异常,或者超出父类范围的异常,但是可以抛出更少、更有限的异常,或者不抛出异常。
1700438640
1700438641 估计你已经猜测出下面要讲的内容了,为什么“参数列表必须与被重写方法的相同”采用不同的字体,这其中是不是有什么玄机?是的,还真有那么一点点小玄机。参数列表相同包括三层意思:参数数量相同、类型相同、顺序相同,看上去好像没什么问题,那我们来看一个例子,业务场景与上一个建议相同,商品打折,代码如下:
1700438642
1700438643 public class Client{
1700438644
1700438645 public static void main(String[]args){
1700438646
1700438647 //向上转型
1700438648
1700438649 Base base=new Sub();
1700438650
1700438651 base.fun(100,50);
1700438652
1700438653 //不转型
1700438654
1700438655 Sub sub=new Sub();
1700438656
1700438657 sub.fun(100,50);
1700438658
1700438659 }
[ 上一页 ]  [ :1.70043861e+09 ]  [ 下一页 ]