java向上转型,java向上转型有什么用

发布时间:2023-01-03

本文目录一览:

  1. 在java里面的向上转型和向下转型的具体好处在哪里?
  2. 在java 中,什么叫向上转型?
  3. 在java 中,什么叫向上转型
  4. 关于java的向上转型
  5. java中关于向上转型的问题
  6. java向上转型有什么作用

在java里面的向上转型和向下转型的具体好处在哪里?

java里面的向上转型和向下转型的具体好处如下:

  1. 转型是在继承的基础上而言的,继承是面向对象语言中,代码复用的一种机制,通过继承,子类可以复用父类的功能,如果父类不能满足当前子类的需求,则子类可以重写父类中的方法来加以扩展。
  2. 向上转型:子类引用的对象转换为父类类型称为向上转型。通俗地说就是是将子类对象转为父类对象。此处父类对象可以是接口 向上转型时,父类指向子类引用对象会遗失除与父类对象共有的其他方法,也就是在转型过程中,子类的新有的方法都会遗失掉,在编译时,系统会提供找不到方法的错误。实例如下:
public class Animal {
    public void eat(){
        System.out.println("animal eatting...");
    }
}
class Bird extends Animal{
    public void eat(){
        System.out.println("bird eatting...");
    }
    public void fly(){
        System.out.println("bird flying...");
    }
}
class Main{          
    public static void main(String[] args) {
        Animal b=new Bird(); //向上转型
        b.eat();
        b.fly();  //此处提示在Animal中没有定义fly方法。
    }
}

在java 中,什么叫向上转型?

java 转型问题其实并不复杂,只要记住一句话:父类引用指向子类对象。 什么叫父类引用指向子类对象,且听我慢慢道来。 从2个名词开始说起:向上转型(upcasting) 、向下转型(downcasting). 举个例子:有2个类,Father是父类,Son类继承自Father。

Father f1 = new Son(); // 这就叫 upcasting (向上转型)
// 现在f1引用指向一个Son对象
Son s1 = (Son)f1; // 这就叫 downcasting (向下转型)
// 现在f1还是指向Son对象

第2个例子:

Father f2 = new Father();
Son s2 = (Son)f2; // 出错,子类引用不能指向父类对象

你或许会问,第1个例子中:Son s1 = (Son)f1;问什么 是正确的呢。 很简单因为f1指向一个子类对象,Father f1 = new Son(); 子类s1引用当然可以指向子类对象了。 而f2 被传给了一个Father对象,Father f2 = new Father();子类s1引用不能指向父类对象。 总结:

  1. 父类引用指向子类对象,而子类引用不能指向父类对象。
  2. 把子类对象直接赋给父类引用叫upcasting向上转型,向上转型不用强制转换。 如:Father f1 = new Son();
  3. 把指向子类对象的父类引用赋给子类引用叫向下转型(downcasting),要强制转换。 如:f1 就是一个指向子类对象的父类引用。把f1赋给子类引用s1即 Son s1 = (Son)f1; 其中f1前面的(Son)必须加上,进行强制转换。 一、向上转型。 通俗地讲即是将子类对象转为父类对象。此处父类对象可以是接口。 1,向上转型中的方法调用。 看下面代码:
package com.wensefu.others; 
public class Animal { 
    public void eat(){ 
        System.out.println("animal eatting..."); 
    } 
} 
class Bird extends Animal{ 
    public void eat(){ 
        System.out.println("bird eatting..."); 
    } 
    public void fly(){ 
        System.out.println("bird flying..."); 
    } 
} 
class Main{ 
    public static void main(String[] args) { 
        Animal b=new Bird(); //向上转型 
        b.eat(); 
        //! error: b.fly(); b虽指向子类对象,但此时丢失fly()方法 
        dosleep(new Male()); 
        dosleep(new Female()); 
    } 
    public static void dosleep(Human h) { 
        h.sleep(); 
    } 
}
package com.wensefu.others; 
public class Human { 
    public void sleep() { 
        System.out.println("Human sleep.."); 
    } 
} 
class Male extends Human { 
    @Override 
    public void sleep() { 
        System.out.println("Male sleep.."); 
    } 
} 
class Female extends Human { 
    @Override 
    public void sleep() { 
        System.out.println("Female sleep.."); 
    } 
}

注意这里的向上转型:

Animal b=new Bird(); //向上转型
b.eat();

此处将调用子类的eat()方法。原因:b实际指向的是Bird子类,故调用时会调用子类本身的方法。 需要注意的是向上转型时b会遗失除与父类对象共有的其他方法。如本例中的fly方法不再为b所有。 2,向上转型的好处。 看上面的代码,

public static void dosleep(Human h) {
    h.sleep();
}

这里以父类为参数,调有时用子类作为参数,就是利用了向上转型。这样使代码变得简洁。不然的话, 如果dosleep以子类对象为参数,则有多少个子类就需要写多少个函数。这也体现了JAVA的抽象编程思想。 二、向下转型。 与向上转型相反,即是把父类对象转为子类对象。 看下面代码:

package com.wensefu.other1; 
public class Girl { 
    public void smile(){ 
        System.out.println("girl smile()..."); 
    } 
} 
class MMGirl extends Girl{ 
    @Override 
    public void smile() { 
        System.out.println("MMirl smile sounds sweet..."); 
    } 
    public void c(){ 
        System.out.println("MMirl c()..."); 
    } 
} 
class Main{ 
    public static void main(String[] args) { 
        Girl g1=new MMGirl(); //向上转型 
        g1.smile(); 
        MMGirl mmg=(MMGirl)g1; //向下转型,编译和运行皆不会出错 
        mmg.smile(); 
        mmg.c(); 
        Girl g2=new Girl(); 
        // MMGirl mmg1=(MMGirl)g2; //不安全的向下转型,编译无错但会运行会出错 
        // mmg1.smile(); 
        // mmg1.c(); 
        /*output: 
        * CGirl smile sounds sweet... 
        * CGirl smile sounds sweet... 
        * CGirl c()... 
        * Exception in thread "main" java.lang.ClassCastException: com.wensefu.other1.Girl 
        * at com.wensefu.other1.Main.main(Girl.java:36) 
        */ 
        if(g2 instanceof MMGirl){ 
            MMGirl mmg1=(MMGirl)g2; 
            mmg1.smile(); 
            mmg1.c(); 
        } 
    } 
}

Girl g1=new MMGirl(); //向上转型 g1.smile(); MMGirl mmg=(MMGirl)g1; //向下转型,编译和运行皆不会出错 这里的向下转型是安全的。因为g1指向的是子类对象。 而 Girl g2=new Girl(); MMGirl mmg1=(MMGirl)g2; //不安全的向下转型,编译无错但会运行会出错 运行出错: Exception in thread "main" java.lang.ClassCastException: com.wensefu.other1.Girl at com.wensefu.other1.Main.main(Girl.java:36) 如代码所示,可以通过instanceof来防止出现异常。

在java 中,什么叫向上转型

java 转型问题其实并不复杂,只要记住一句话:父类引用指向子类对象。 什么叫父类引用指向子类对象,且听我慢慢道来. 从2个名词开始说起:向上转型(upcasting) 、向下转型(downcasting). 举个例子:有2个类,Father是父类,Son类继承自Father。

Father f1 = new Son(); // 这就叫 upcasting (向上转型)
// 现在f1引用指向一个Son对象
Son s1 = (Son)f1; // 这就叫 downcasting (向下转型)
// 现在f1还是指向Son对象

第2个例子:

Father f2 = new Father();
Son s2 = (Son)f2; // 出错,子类引用不能指向父类对象

你或许会问,第1个例子中:Son s1 = (Son)f1;问什么 是正确的呢。 很简单因为f1指向一个子类对象,Father f1 = new Son(); 子类s1引用当然可以指向子类对象了。 而f2 被传给了一个Father对象,Father f2 = new Father();子类s1引用不能指向父类对象。 总结:

  1. 父类引用指向子类对象,而子类引用不能指向父类对象。
  2. 把子类对象直接赋给父类引用叫upcasting向上转型,向上转型不用强制转换。 如:Father f1 = new Son();
  3. 把指向子类对象的父类引用赋给子类引用叫向下转型(downcasting),要强制转换。 如:f1 就是一个指向子类对象的父类引用。把f1赋给子类引用s1即 Son s1 = (Son)f1; 其中f1前面的(Son)必须加上,进行强制转换。 一、向上转型。 通俗地讲即是将子类对象转为父类对象。此处父类对象可以是接口。 1,向上转型中的方法调用。 看下面代码: [java] view plaincopyprint?
package com.wensefu.others;
public class Animal {
public void eat(){
System.out.println("animal eatting...");
}
}
class Bird extends Animal{
public void eat(){
System.out.println("bird eatting...");
}
public void fly(){
System.out.println("bird flying...");
}
}
class Main{
public static void main(String[] args) {
Animal b=new Bird(); //向上转型
b.eat();
//! error: b.fly(); b虽指向子类对象,但此时丢失fly()方法
dosleep(new Male());
dosleep(new Female());
}
public static void dosleep(Human h) {
h.sleep();
}
}

[java] view plaincopyprint?

package com.wensefu.others;
public class Human {
public void sleep() {
System.out.println("Human sleep..");
}
}
class Male extends Human {
@Override
public void sleep() {
System.out.println("Male sleep..");
}
}
class Female extends Human {
@Override
public void sleep() {
System.out.println("Female sleep..");
}
}

注意这里的向上转型: Animal b=new Bird(); //向上转型 b.eat(); 此处将调用子类的eat()方法。原因:b实际指向的是Bird子类,故调用时会调用子类本身的方法。 需要注意的是向上转型时b会遗失除与父类对象共有的其他方法。如本例中的fly方法不再为b所有。 2,向上转型的好处。 看上面的代码, public static void dosleep(Human h) { h.sleep(); } 这里以父类为参数,调有时用子类作为参数,就是利用了向上转型。这样使代码变得简洁。不然的话, 如果dosleep以子类对象为参数,则有多少个子类就需要写多少个函数。这也体现了JAVA的抽象编程思想。 二、向下转型。 与向上转型相反,即是把父类对象转为子类对象。 看下面代码: [java] view plaincopyprint?

package com.wensefu.other1;
public class Girl {
public void smile(){
System.out.println("girl smile()...");
}
}
class MMGirl extends Girl{
@Override
public void smile() {
System.out.println("MMirl smile sounds sweet...");
}
public void c(){
System.out.println("MMirl c()...");
}
}
class Main{
public static void main(String[] args) {
Girl g1=new MMGirl(); //向上转型
g1.smile();
MMGirl mmg=(MMGirl)g1; //向下转型,编译和运行皆不会出错
mmg.smile();
mmg.c();
Girl g2=new Girl();
// MMGirl mmg1=(MMGirl)g2; //不安全的向下转型,编译无错但会运行会出错
// mmg1.smile();
// mmg1.c();
/*output:
* CGirl smile sounds sweet...
* CGirl smile sounds sweet...
* CGirl c()...
* Exception in thread "main" java.lang.ClassCastException: com.wensefu.other1.Girl
* at com.wensefu.other1.Main.main(Girl.java:36)
*/
if(g2 instanceof MMGirl){
MMGirl mmg1=(MMGirl)g2;
mmg1.smile();
mmg1.c();
}
}
}

Girl g1=new MMGirl(); //向上转型 g1.smile(); MMGirl mmg=(MMGirl)g1; //向下转型,编译和运行皆不会出错 这里的向下转型是安全的。因为g1指向的是子类对象。 而 Girl g2=new Girl(); MMGirl mmg1=(MMGirl)g2; //不安全的向下转型,编译无错但会运行会出错 运行出错: Exception in thread "main" java.lang.ClassCastException: com.wensefu.other1.Girl at com.wensefu.other1.Main.main(Girl.java:36) 如代码所示,可以通过instanceof来防止出现异常。

关于java的向上转型

来自CSDN。通俗易懂。 我们在现实中常常这样说:这个人会唱歌。在这里,我们并不关心这个人是黑人还是白人,是成人还是小孩,也就是说我们更倾向于使用抽象概念“人”。再例如,麻雀是鸟类的一种(鸟类的子类),而鸟类则是动物中的一种(动物的子类)。我们现实中也经常这样说:麻雀是鸟。这两种说法实际上就是所谓的向上转型,通俗地说就是子类转型成父类。这也符合Java提倡的面向抽象编程思想。来看下面的代码:

package a.b;
public class A {
public void a1() {
System.out.println("Superclass");
}
}

A的子类B:

package a.b;
public class B extends A {
public void a1() {
System.out.println("Childrenclass"); //覆盖父类方法
}
public void b1(){} //B类定义了自己的新方法
}

C类:

package a.b;
public class C {
public static void main(String[] args) {
A a = new B(); //向上转型
a.a1();
}
}

如果运行C,输出的是Superclass 还是Childrenclass?不是你原来预期的Superclass,而是Childrenclass。这是因为a实际上指向的是一个子类对象。当然,你不用担心,Java虚拟机会自动准确地识别出究竟该调用哪个具体的方法。不过,由于向上转型,a对象会遗失和父类不同的方法,例如b1()。有人可能会提出疑问:这不是多此一举吗?我们完全可以这样写:

B a = new B();
a.a1();

确实如此!但这样就丧失了面向抽象的编程特色,降低了可扩展性。其实,不仅仅如此,向上转型还可以减轻编程工作量。来看下面的显示器类Monitor:

package a.b;
public class Monitor{
public void displayText() {}
public void displayGraphics() {}
}

液晶显示器类LCDMonitor是Monitor的子类:

package a.b;
public class LCDMonitor extends Monitor {
public void displayText() {
System.out.println("LCD display text");
}
public void displayGraphics() {
System.out.println("LCD display graphics");
}
}

阴极射线管显示器类CRTMonitor自然也是Monitor的子类:

package a.b;
public class CRTMonitor extends Monitor {
public void displayText() {
System.out.println("CRT display text");
}
public void displayGraphics() {
System.out.println("CRT display graphics");
}
}

等离子显示器PlasmaMonitor也是Monitor的子类:

package a.b;
public class PlasmaMonitor extends Monitor {
public void displayText() {
System.out.println("Plasma display text");
}
public void displayGraphics() {
System.out.println("Plasma display graphics");
}
}

现在有一个MyMonitor类。假设没有向上转型,MyMonitor类代码如下:

package a.b;
public class MyMonitor {
public static void main(String[] args) {
run(new LCDMonitor());
run(new CRTMonitor());
run(new PlasmaMonitor());
}
public static void run(LCDMonitor monitor) {
monitor.displayText();
monitor.displayGraphics();
}
public static void run(CRTMonitor monitor) {
monitor.displayText();
monitor.displayGraphics();
}
public static void run(PlasmaMonitor monitor) {
monitor.displayText();
monitor.displayGraphics();
}
}

可能你已经意识到上述代码有很多重复代码,而且也不易维护。有了向上转型,代码可以更为简洁:

package a.b;
public class MyMonitor {
public static void main(String[] args) {
run(new LCDMonitor()); //向上转型
run(new CRTMonitor()); //向上转型
run(new PlasmaMonitor()); //向上转型
}
public static void run(Monitor monitor) { //父类实例作为参数
monitor.displayText();
monitor.displayGraphics();
}
}

我们也可以采用接口的方式,例如:

package a.b;
public interface Monitor {
abstract void displayText();
abstract void displayGraphics();
}

将液晶显示器类LCDMonitor稍作修改:

package a.b;
public class LCDMonitor implements Monitor {
public void displayText() {
System.out.println("LCD display text");
}
public void displayGraphics() {
System.out.println("LCD display graphics");
}
}

CRTMonitor、PlasmaMonitor类的修改方法与LCDMonitor类似,而MyMonitor可以不不作任何修改。 可以看出,向上转型体现了类的多态性,增强了程序的简洁性。

java中关于向上转型的问题

RTTI机制 向上转型的目的仍然是抽象。 比如 水果有颜色、味道。不同的水果有不同的颜色和味道。那么当 水果 sg

new 橘子(); 水果 sg1

new 苹果(); sg.color();sg.taste(); sg1.color();sg1.taste(); sg,sg1都是水果实例的引用。但会调用不同的具体子类的方法。 其目地都是抽象。通过访问父类或接口的方法(公共)达到一种对具体实现的封装。对于接口的使用者来说,不需要关心实现细节。提高内聚,降低不必要的耦合。 再多说一句:注意转型时带来的 内存切片。

java向上转型有什么作用

java里面的向上转型和向下转型的具体好处如下: 1.转型是在继承的基础上而言的,继承是面向对象语言中,代码复用的一种机制,通过继承,子类可以复用父类的功能,如果父类不能满足当前子类的需求,则子类可以重写父类中的方法来加以扩展。