Java:什么是向上转型与向下转型(详细图解)

目录

一、什么是向上转型

1、概念

2、代码示例

3、向上转型的优缺点

二、什么是向下转型

1、向下转型的概念

​编辑

2、代码示例

三、向下转型的缺点及 instanceof 的使用

1、向下转型的缺点

2、instanceof的使用


一、什么是向上转型

1、概念

向上转型就是创建一个子类对象,将其当成父类对象来使用

语法格式:父类类型  对象名  =  new  子类类型()

                     Animal   animal  =  new Cat ();

Animal 是父类类型,但可以引用 Cat这个子类类型,因为是从小范围到大范围的转换。

2、代码示例

class Aminal {
    public void display() {
        System.out.println("Animal");
    }
}
class Cat extends Aminal {
    public void display() {
        System.out.println("Cat");
    }
}
class Dog extends Aminal {

}

public class Main{
    public static void main(String[] args) {
        Aminal aminal1 = new Aminal();
        Aminal aminal2 = new Cat();
        Aminal aminal3 = new Dog();

        aminal1.display();
        aminal2.display();
        aminal3.display();
    }
}

animal2中,Cat类 重写了 display方法,所以在实现时,打印的是Cat类中实现的内容。

animal3中,Dog类 没有重写 display方法,所以打印的还是父类中的内容。

由此我们可以得出:向上转型实现时

                                先看子类有没有

                                若是子类找不到

                                再看父类有没有

                                二者都无则报错!

3、向上转型的优缺点

优点:让代码实现更简单灵活

缺点:不能调用到子类特有的方法

例如:

class Animal {
    public void display() {
        System.out.println("Animal");
    }
}

class Dog extends Animal {
    public void display() {
        System.out.println("dog");
    }

    public void eat() {
        System.out.println("吃骨头");
    }
}

public class Main {
    public static void main(String[] args) {
        Animal animal = new Dog();

        animal.display();
        animal.eat(); //会报错
    }
}

所以,向上转型无法调用子类特有的方法!

二、什么是向下转型

1、向下转型的概念

将一个子类对象向上转型之后可以当成父类对象使用,若需要调用子类特有的方法,则需要将父类对象再还原为子类对象。这就称作向下转型。

2、代码示例

class Animal {
    public void display() {
        System.out.println("Animal");
    }
}

class Dog extends Animal {
    public void display() {
        System.out.println("dog");
    }

    public void eat() {
        System.out.println("吃骨头");
    }
}

public class Main{
    public static void main(String[] args) {
        //向上转型
        Animal animal = new Dog();
        animal.display();
        
        //向下转型
        //Animal类中原本没有 eat方法,在向下转型之前如果调用eat方法会报错
        //向下转型为子类Dog类后,就可以调用子类中特有的方法,而不会报错
        animal = (Dog)animal;
        ((Dog) animal).eat();
    }
}

运行结果:

三、向下转型的缺点及 instanceof 的使用

1、向下转型的缺点

缺点:向下转型使用的比较少,而且不安全。如果转换失败,运行时就会抛异常。

2、instanceof的使用

Java中为了提高向下转型的安全性,引入了instanceof。如果表达式为 true,则可以安全转换。

使用实例:

class Animal {
    public void display() {
        System.out.println("Animal");
    }
}

class Dog extends Animal {
    public void display() {
        System.out.println("dog");
    }

    public void eat() {
        System.out.println("吃骨头");
    }
}
public class Main {
    public static void main(String[] args) {
        //向上转型
        Animal animal = new Dog();
        
        //判断instanceof 是否为 true
        if(animal instanceof Dog) {
            //向下转型
            animal = (Dog)animal;
            ((Dog) animal).eat();
        } else {
            System.out.println("Animal无法向下转型为Dog");
        }
    }
}

 以上就是 Java:什么是向上转型与向下转型(详细图解)的全部内容了,希望能对您有所帮助!

您的点赞与收藏就是对我最大的支持!

  • 33
    点赞
  • 35
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
自底向上归并排序和自顶向下归并排序都是归并排序的实现方式。 自底向上归并排序(Bottom-up Merge Sort)是一种迭代的排序算法。它从最小粒度的子数组开始,将相邻的子数组两两归并,然后再将得到的更大的子数组两两归并,直至整个数组排序完成。整个过程不依赖于递归。 下面是自底向上归并排序的图解示例: 1. 对输入数组进行初次划分,将每个元素看作一个独立的子数组。 [4, 3, 2, 1] -> [, , , ] 2. 两两归并相邻的子数组。 [, , , ] -> [[3, 4], [1, 2]] 3. 再次两两归并相邻的子数组。 [[3, 4], [1, 2]] -> [[1, 2, 3, 4]] 4. 最终得到完全排序的数组。 [[1, 2, 3, 4]] -> [1, 2, 3, 4] 自顶向下归并排序(Top-down Merge Sort)是一种递归的排序算法。它将原始数组逐步划分为更小的子数组,然后递归地对子数组进行排序,最终再将这些有序的子数组进行归并,得到完全排序的数组。 下面是自顶向下归并排序的图解示例: 1. 对输入数组进行划分,将其一分为二。 [4, 3, 2, 1] -> [4, 3], [2, 1] 2. 递归地对划分后的子数组进行排序,并将其归并。 [4, 3] -> [3, 4] [2, 1] -> [1, 2] 归并结果:[3, 4], [1, 2] 3. 最终对归并的结果进行合并。 [3, 4], [1, 2] -> [1, 2, 3, 4] 以上就是自底向上和自顶向下归并排序的图解示例。两种方式最终都能得到完全排序的数组,只是实现方式略有不同。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值