打字猴:1.700438695e+09
1700438695 事实上,base对象是把子类对象Sub做了向上转型,形参列表是由父类决定的,由于是变长参数,在编译时,“base.fun(100,50)”中的“50”这个实参会被编译器“猜测”而编译成“{50}”数组,再由子类Sub执行。我们再来看看直接调用子类的情况,这时编译器并不会把“50”做类型转换,因为数组本身也是一个对象,编译器还没有聪明到要在两个没有继承关系的类之间做转换,要知道Java是要求严格的类型匹配的,类型不匹配编译器自然就会拒绝执行,并给予错误提示。
1700438696
1700438697 这是个特例,覆写的方法参数列表竟然与父类不相同,这违背了覆写的定义,并且会引发莫名其妙的错误。所以读者在对变长参数进行覆写时,如果要使用此类似的方法,请找个小黑屋仔细想想是不是一定要如此。
1700438698
1700438699 注意 覆写的方法参数与父类相同,不仅仅是类型、数量,还包括显示形式。
1700438700
1700438701
1700438702
1700438703
1700438704 编写高质量代码:改善Java程序的151个建议 [:1700438074]
1700438705 编写高质量代码:改善Java程序的151个建议 建议7:警惕自增的陷阱
1700438706
1700438707 记得大学刚开始学C语言时,老师就说:自增有两种形式,分别是i++和++i, i++表示的是先赋值后加1,++i是先加1后赋值,这样理解了很多年也没出现问题,直到遇到如下代码,我才怀疑我的理解是不是错了:
1700438708
1700438709 public class Client{
1700438710
1700438711 public static void main(String[]args){
1700438712
1700438713 int count=0;
1700438714
1700438715 for(int i=0;i<10;i++){
1700438716
1700438717 count=count++;
1700438718
1700438719 }
1700438720
1700438721 System.out.println(“count=”+count);
1700438722
1700438723 }
1700438724
1700438725 }
1700438726
1700438727 这个程序输出的count等于几?是count自加10次吗?答案等于10?可以非常肯定地告诉你,答案错误!运行结果是count等于0。为什么呢?
1700438728
1700438729 count++是一个表达式,是有返回值的,它的返回值就是count自加前的值,Java对自加是这样处理的:首先把count的值(注意是值,不是引用)拷贝到一个临时变量区,然后对count变量加1,最后返回临时变量区的值。程序第一次循环时的详细处理步骤如下:
1700438730
1700438731 步骤1 JVM把count值(其值是0)拷贝到临时变量区。
1700438732
1700438733 步骤2 count值加1,这时候count的值是1。
1700438734
1700438735 步骤3 返回临时变量区的值,注意这个值是0,没修改过。
1700438736
1700438737 步骤4 返回值赋值给count,此时count值被重置成0。
1700438738
1700438739 “count=count++”这条语句可以按照如下代码来理解:
1700438740
1700438741 public static int mockAdd(int count){
1700438742
1700438743 //先保存初始值
1700438744
[ 上一页 ]  [ :1.700438695e+09 ]  [ 下一页 ]