父类引用指向子类对象 调用函数常见问题

本文探讨了Java中父类引用调用子类对象时的常见问题,即只能调用子类中与父类同名的方法。通过示例说明了在调用重载方法时,虚拟机会依据参数的静态类型而非动态类型来选择合适的方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

解决父类引用调用子类对象当中,引用调用函数的常见问题。该引用只能调用子类中与父类同名的函数,否则报错。

虚拟机在调用重载函数时,是通过参数的静态类型作为调用重载函数的判定依据,而不是动态类型

 

 

 

public class Dis
{
static class QQ {}

static class _360 {}

static class sqq extends QQ{}

public static class F{

public void f1(QQ arg)
{
System.out.println("F QQ");
}

public void f1(_360 arg)
{
System.out.println("F 360");
}

//public void f1(sqq arg)
//{
System.out.println("F sqq 360");
//}

}


public static class S extends F{

public void f1(QQ arg)
{
System.out.println("S QQ");
}

public void f1(_360 arg)
{
System.out.println("S 360");
}
public void f1(sqq arg)
{
System.out.println("s sqq 360");
}

}


public static void main(String[] args){


F son = new S();//son只能调用子类中与父类同名的函数,否则报错.

sqq sq = new sqq();

 

son.f1(sq);//调用重载函数时,找不到对应数据类型的重载函数,就会寻找离该数据类型最近的重载函数(自动类型转化)
//不注释父类的f1(sqq arg),打印出s sqq 360,注释父类的f1(sqq arg),打印S QQ

 

QQ qq = new sqq();

//qq 是静态类型,new sqq()是动态类型

//虚拟机在重载时,是通过参数的静态类型作为判定依据,而不是动态类型

son.f1(qq);

//打印结果是S QQ

}

}

转载于:https://www.cnblogs.com/yxjr/p/7602296.html

### C++ 中父类引用指向子类对象的多态使用方法 在 C++ 的面向对象编程中,通过 **父类引用指向子类对象** 可以实现运行时多态行为。这种机制依赖于虚函数(virtual function),它允许程序在运行时决定调用哪个版本的方法。 #### 虚函数的作用 为了支持多态,C++ 提供了 `virtual` 关键字来声明虚函数。当一个基类中的成员函数被标记为虚拟时,在派生类中重新定义该函数会覆盖原始定义[^4]。如果通过基类类型的指针或引用来访问这个函数,则实际执行的是派生类中对应的实现[^3]。 下面是一个具体的例子展示如何利用父类引用调用子类的功能: ```cpp #include <iostream> using namespace std; // 定义基类 class Animal { public: virtual void speak() const { cout << "Some sound..." << endl; } // 声明为虚函数 }; // 定义第一个派生类 class Cat : public Animal { public: void speak() const override { cout << "Meow!" << endl; } }; // 定义第二个派生类 class Dog : public Animal { public: void speak() const override { cout << "Woof!" << endl; } }; void makeSound(const Animal& animal) { // 接收基类引用作为参数 animal.speak(); } int main() { Cat myCat; Dog myDog; makeSound(myCat); // 输出 Meow! makeSound(myDog); // 输出 Woof! return 0; } ``` 在这个案例里,尽管 `makeSound()` 函数接受的是 `Animal` 类型的常量引用,但由于 `speak()` 是虚函数,因此能够正确地调用了传递给它的具体动物类型的声音方法。 #### 注意事项 - 如果没有将基类中的方法设置成虚函数,则即使存在同名方法也不会触发动态绑定,而是按照静态类型解析规则处理。 - 构造函数和析构函数不能是虚函数;但是建议把基类的析构函数设为纯虚或者至少是普通的虚函数以便安全销毁派生类实例。 #### 总结 借助虚函数的支持,C++ 实现了基于父类引用操作子类对象的能力,并借此达成真正的运行期多态效果。这不仅增强了代码灵活性还促进了良好的设计模式应用如策略模式等[^5]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值