zoukankan      html  css  js  c++  java
  • 方法的重载和方法的重写

      方法的重载是平行关系,就是在类中可以创建多个方法,它们具有相同的名字,但具有不同的参数和不同的定义(返回值的数据类型可以相同,也可以不同,但参数的数据类型或者参数的数量必须不同,否则无法通过编译);

    package overrideAndovrload;
    
    public class OverrideAndOverload { //方法的重载和方法的重写
        public int OverRide(int a){
            return 0;
        }
        
        
         private int OverRide(){
            return 0;
        }
        
        public int OverRide(double b){
            return 0;
        }
        
        public double OverRide(String b){
            return 0;
        }
        
        /** 报错:返回值数据类型不同,但参数的数据类型和已有的方法相同
         * public String OverRide(String b){
            return 0;
        }*/
        
    }

      方法的重写,是子类与父类之间的一种垂直关系,提现父类与子类之间的多态性,既子类对父类的函数进行重新定义——相同参数,不同实现(动态多态性)。

    package overrideAndovrload;
    
    public class OverrideAndOverload { //方法的重载和方法的重写
        public int OverRide(int a){
            return 0;
        }
        
        
         private int OverRide(){
            return 0;
        }
        
        public int OverRide(double b){
            return 0;
        }
        
        public double OverRide(String b){
            return 0;
        }
        
        /** 报错:返回值数据类型不同,但参数的书籍类型和已有的方法相同
         * public String OverRide(String b){
            return 0;
        }*/
        
    }
    
    class Test extends OverrideAndOverload{
        /**  不合法:方法的重写必须保证和父类方法的结构相同
         * public String OverRide(int a){
            return 0;
        }*/
        
        public int OverRide(int a){
            return 0;
        }
        
        public int OverRide(double a,int b){//合法:参数数量不同
            return 0;
        }
    }

       总结:方法的重载和方法的重写,是通过参数的重载和重写来实现的。这是因为在java中所有方法的调用都是通过参数的不同来判断调用的是哪一个方法。思考一个问题:有如下两个方法

        void f(){}

        int f() {}

      若编译器可根据上下文(语境)明确判断出含义,比如在 int x=f()中,那么这样做完全没有问题。然而, 我们也可能调用一个方法,同时忽略返回值;我们通常把这称为“为它的副作用去调用一个方法”,因为我 们关心的不是返回值,而是方法调用的其他效果。所以假如我们象下面这样调用方法: f();Java 怎样判断f()的具体调用方式呢?而且别人如何识别并理解代码呢?由于存在这一类的问题,所以不能 根据返回值类型来区分过载的方法。

      我发现这些所有的问题都能在《Think in java》这本书里面找到答案,有需要这本书的小伙伴可以给我留言,我可以将电子版发给你!有不一样的见解或看法,欢迎给我留言,大家一起讨论一起进步。

  • 相关阅读:
    距离的总和
    [leetcode] 397. Integer Replacement
    [leetcode] 396. Rotate Function
    [leetcode] 398. Random Pick Index
    [leetcode] 399. Evaluate Division
    [算法] get_lucky_price price
    Geoserver(一) Geoserver2.15.4配置发布arcgis切片
    Geoserver(二) geoserver配置mysql插件
    OpenLayers4地图实例-功能齐全
    OpenLayers Node环境安装运行构建-支持Vue集成OpenLayers
  • 原文地址:https://www.cnblogs.com/caoleiCoding/p/6392701.html
Copyright © 2011-2022 走看看