黑马程序员——Java继承

本文深入解析Java中的继承机制,包括其优点、成员特点、覆盖注意事项以及构造函数的特性和应用。并通过具体示例展示了如何使用继承设计员工类和经理类,以及模版方法设计模式的应用。

---------------------- <a href="http://edu.youkuaiyun.com/heima" target="blank">android培训</a>、<a href="http://edu.youkuaiyun.com/heima" target="blank">java培训</a>、期待与您交流! ----------------------

 

      继承是面向对象语言的重要机制。借助继承,可以扩展原有的代码,应用到其他程序中,而不必重新编写这些代码。在java语言中,继承是通过扩展原有的类, 声明新类来实现的。扩展声明的新类称为子类,原有的类称为超类(父类)。继承机制规定,子类可以拥有超类的所有属性和方法,也可以扩展定义自己特有的属 性,增加新方法和重新定义超类的方法。

      继承的优点:
      1,提高了代码的复用性
      2,让类之间产生了关系。有了这个关系,才有了多态的特性
      注意:千万不要为了获取其他类的功能,简化代码而继承, 必须是类与类之间有所属关系才可以继承,所属关系is a。
      子类父类出现后,类成员的特点:
      1,变量
      如果类中出现非私有的同名成员变量时子类要访问本类中的变量,用this;子类要访问父类中的同名变量,用supper。
      supper的使用和this的使用几乎一致,this代表的是本类对象的引用,supper代表的是父类对象的引用。
      2,函数
      当子类出现和父类一模一样的函数时,当子类对象调用该函数,会运行子类函数的内容,如同父类的函数被覆盖一样,这中情况是函数的另一个特性:重写(覆盖)。当子类继承了父类,沿袭了父类的功能到子类中,但是子类虽具备该功能,但是功能的内容却和父类不一致,这时,没有必要定义新功能,而是使用覆盖特性,保留父类功能的定义,并重写功能内容。

     覆盖注意事项:
     1,子类覆盖父类,必须保证子类权限大于等于父类权限,才可以覆盖,否则编译失败。
     2,静态只能覆盖静态。
     注意:重载:只看同名函数的参数列表;重写:子父类的方法要一模一样。

     3,构造函数
     在对子类对象进行初始化时,父类的构造函数也会进行,那是因为子类的构造函数默认第一行有一条隐式语句supper(),supper();会访问父类中空参数的构造函数,而且子类中所有的构造函数默认第一行都是supper();。

     为什么子类一定要访问父类中的构造函数
     因为父类中的数据子类可以直接获取,所以子类对象在建立时,需要先查看父类是如何对这些数据进行初始化的。所以子类在对象初始化时,先要访问一下父类中的构造函数,如果要访问父类中指定的构造函数,可以通过手动定义supper语句来指定。
    注意:supper语句一定定义在子类构造函数的第一行。

    子类的实例化过程:
    结论:子类所有的构造函数默认都会访问父类中空函数的构造函数,因为子类没一个构造函数的第一行都有一句隐式supper();。
    当父类中没有空参数的构造函数时,子类必须手动通过supper或者this语句形式来指定要访问的构造函数。
    当然:子类的构造函数第一行也可以手动指定this语句来访问本类中的构造函数。子类总至少会有一个构造函数会访问父类中的构造函数。

 

例子一:

     假设我们在开发一个系统时需要对员工进行建模,员工包含3个属性:姓名,工号以及工资,经理也是员工,除了包含员工的属性外还有一个奖金属性。请使用继承的思想设计出员工类和经理类。要求类中提供必要的方法进行属性访问。

/*

分析:
员工类:name id pay
经理类:继承了员工,并有自己的bonur

*/
class Employee
{
    private String name;
    private String id;
    private double pay;

    Employee(String name,String id,double pay)
    {
        this.name=name;
        this.id=id;
        this.pay=pay;
    }
    public abstract void work();

}
class Manger extends Employee
{
    int bonus;
    Manger(String name,String id,double pay,int bonus)
    {
        super(name,id,pay);
        this.bonus=bonus;
    }
    public void work()
    {
        System.out.print("Manger work")    
    }
}
class  Proextends Employee
{
    pro (String name,String id,double pay)
    {
        super(name,id,pay);
    }
    public void work()
    {
        System.out.print("Pro work")    
    }
}
class    
{
    public static void main(String[] args)
    {
        System.out.print("hello world!")
    }
}

 

 

例子二:

     /*
需求:获取一段程序运行的时间
原来:获取程序开始和结束的时间并相减即可

获取时间:System.currentTimeMillis();

当代码完成优化后就可以解决这类问题
这种方式,叫做模版方法设计模式
什么是模版方法呢?
在定义功能时,功能的一部分是确定的,但是有一部分是不确定的,而确定的部分在使用不确定的部分,
那么这时就将不确定的部分暴露 出去,由该类的子类去完成

*/

abstract class GetTime
{
    public final void getTime()
    {
        long start=System.currentTimeMillis();
        runcode();
        long end=System.currentTimeMillis();
        System.out.println("运行的时间"+(end-star));
    }
    public abstract void runcode();
}
    

class SubTime extends GetTime
{
    public void runcode()
    {
        for(int x=0;x<3000; x++)
        {
            System.out.print(x);
        }
    }
}
class Temp
{
    public static void main(String[] args)
    {
        SubTime gt=new SubTime();
        gt。getTime();
    }
}


---------------------- <a href="http://edu.youkuaiyun.com/heima" target="blank">android培训</a>、<a href="http://edu.youkuaiyun.com/heima" target="blank">java培训</a>、期待与您交流! ----------------------

详细请查看:<a href="http://edu.youkuaiyun.com/heima" target="blank">http://edu.youkuaiyun.com/heima</a>



 

转载于:https://www.cnblogs.com/onefirst/archive/2012/07/14/2591115.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值