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
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 ]
[
下一页 ]