java中的成员方法与成员变量的继承

一 变量
   子类与父类出现同名时,则子类隐藏父类的同名成员变量(子类与父类变量的类型可以不一样,父类的final或static修饰的变量也可以被隐藏)

 二 成员方法
 

1、方法继承:利用extends关键字一个方法继承另一个方法,而且只能直接继承一个类。


当Sub类和Base类在同一个包时Sub类继承Base类中的public/protected/默认级别的变量个方法
在不同包时继承public/protected级别的变量和方法。


2、方法重载:如果有两个方法的方法名相同但参数不一致(必须的),叫方法的重载:

 

方法名相同
方法的参数类型,个数顺序至少有一项不同
方法的返回类型可以不相同
方法的修饰符可以不相同
main方法也可以被重载

构造方法也可以被重载


3、方法覆盖:如果在子类中定义一个方法,其名称、返回类型及参数签名正好与父类中某个方法的名称、返回类型及参数签名相匹配,那么可以说,子类的方法覆盖了父类的方法。

子类的返回类型与方法签名(名字与参数列表)必须与父类的一致 ,返回类型是父类被覆盖方法返回类型的子类
子类方法不能缩小父类方法的访问权限
 子类方法不能抛出比父类方法更多的异常,且子类抛出的异常必须与父类抛出的异常相同或者是父类抛出异常的子类


方法覆盖只存在于子类和父类之间,同一个类中只能重载

子类可以定义于父类的静态方法同名的静态方法,以便在子类中隐藏父类的静态方法(满足覆盖约束),    
而且Java虚拟机把静态方法和所属的类绑定,而把实例方法和所属的实例绑定。

 
父类的非静态方法不能被子类覆盖为静态方法

父类的静态方法不能被子类覆盖为非静态方法


父类的静态方法能被子类的静态方法“覆盖”(此时叫隐藏,性质与覆盖完全不一样)见后面例子

 

 

父类的私有方法不能被子类覆盖(但是不会出错,因为子类根本没有继承父类的私有方法)

父类的final方法不能被子类覆盖
父类的抽象方法可以被子类通过两种途径覆盖(即实现和覆盖)
父类的非抽象方法可以被覆盖为抽象方法

 

4、Super关键字:super和this关键字都可以用来覆盖Java语言的默认作用域,使被屏蔽的方法或变量变为可见(三种情况下的不可见P171)。

父类的成员变量和方法为private使用super访问编译出错
在类的构造方法种,通过super语句调用这个类的父类的构造方法
在子类种访问父类的被屏蔽的方法和属性
只能在构造方法或实例方法内使用super关键字,而在静态方法和静态代码块内不能使用super


5、多态

对于一个引用类型的变量,Java编译器按照它的声明的类型来处理
对于一个引用类型的变量,运行时Java虚拟机按照它的实际引用的对象来处理
运行时环境中,通过引用类型变量来访问所引用对象的方法和属性时,Java虚拟机采用以下绑定规则

            1)实例方法与引用变量实际引用的对象的方法绑定,属于动态绑定
            2)静态方法与引用变量所声明的类型的方法绑定,属于静态绑定
            3)成员变量(包括静态和实例变量)与引用变量所声明的类型的成员变量绑定,属于静态绑定                                                                                                               

6、继承的利弊和使用原则:

集成数的层次不可太多
集成数的上层为抽象层

            (1)定义了下层子类都用友的相同属性和方法,并且尽可能默认实现,从而提高重用性
            (2)代表系统的接口,描述系统所能提供的服务

继承关系最大的弱点:打破封装
精心设计专门用于被继承的类

            (1)对这些类必须提供良好的文档说明
            (2)尽可能的封装父类的实现细节,把代表时间细节的属性和方法定义为private类型
            (3)如果某些实现细节必须被子类访问,定义为protected类型
            (4)把不允许子类覆盖的方法定义为final类型
            (5)父类的构造方法不允许调用可被子类覆盖的方法
            (6)如果某些类不是专门为了继承而设计,那么随意继承它是不安全的

方法的隐藏例子:

 import java.io.*;
class father {
       static void fun(){
         System.out.println("father"); 
       }
  }

class son extends father
{
        tatic void fun(){
          System.out.println("son");  
        }

}

 public class TestMember{
    public static void main(String[] args) {
  father s=new son();
         s.fun();
  //输出:father      
    }
}

方法的覆盖例子(实现多态)

import java.io.*;
class father {
 final static String name="father";
      void fun(){
  System.out.println("father"); 
  }
     }

class son extends father
{
       //String name="son";
   private int name=90;
         void fun(){
          System.out.println("son");  
 }

}

 public class TestMember{
    public static void main(String[] args) {
  father s=new son();
         s.fun();
  //输出:son     
    }
}

总结

实例方法:子类与父类相同返回类型与相同签名叫覆盖,调用实例对象的方法(运行时指向随就调用谁的方法),是实现运行时多态的基础.


类方法:(static修饰的)子类与父类相同返回类型与相同签名叫隐藏,不管指向谁,调用的是声明类型的方法.

 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值