legongju.com
我们一直在努力
2025-01-19 12:59 | 星期天

C++继承机制怎样处理同名函数

在C++中,如果一个派生类(子类)从基类(父类)继承,并且两个类都有一个同名的成员函数,那么在访问这个同名函数时,派生类中的函数会覆盖基类中的函数。这种行为称为函数重写(Function Overriding)。

当你在派生类中使用基类的成员函数时,编译器会根据对象的实际类型来选择正确的函数。如果对象是基类的实例,那么将调用基类的函数;如果对象是派生类的实例,那么将调用派生类的函数。

下面是一个简单的例子:

#include 

class Base {
public:
    void print() {
        std::cout << "Base class function" << std::endl;
    }
};

class Derived : public Base {
public:
    void print() override { // 使用override关键字明确表示重写
        std::cout << "Derived class function" << std::endl;
    }
};

int main() {
    Base *b = new Base();
    Derived *d = new Derived();

    b->print(); // 输出 "Base class function"
    d->print(); // 输出 "Derived class function"

    delete b;
    delete d;

    return 0;
}

在这个例子中,Derived类重写了Base类的print()函数。当我们通过基类指针调用print()函数时,输出的是基类的函数;而当我们通过派生类指针调用print()函数时,输出的是派生类的函数。

未经允许不得转载 » 本文链接:https://www.legongju.com/article/14506.html

相关推荐

  • c++ mysql库的数据更新与删除操作

    c++ mysql库的数据更新与删除操作

    在C++中,可以使用MySQL C++ Connector库来进行数据更新和删除操作。以下是一个简单的示例代码,展示如何使用MySQL C++ Connector库来进行数据更新和删除操作:<...

  • c++ memset_s与memset有何不同

    c++ memset_s与memset有何不同

    memset_s 和 memset 都是 C++ 中用于设置内存区域的函数,但它们之间存在一些关键差异 安全性:memset_s 是一个更安全的版本,因为它会检查目标缓冲区的大小。如...

  • c++中使用memset_s需要注意什么

    c++中使用memset_s需要注意什么

    在C++中,memset_s函数是一个安全的内存设置函数,它可以防止缓冲区溢出 包含头文件:在使用memset_s之前,请确保已经包含了正确的头文件。对于C++,应该包含头文...

  • c++ memset_s如何安全清零内存

    c++ memset_s如何安全清零内存

    在C++中,memset_s是一个安全的方法来清零内存
    #include
    #include int main() { char buffer[100]; // 填充缓冲区 for (int i = 0; i< sizeof(buffer)...

  • C++构造函数怎样优化内存分配

    C++构造函数怎样优化内存分配

    在C++中,构造函数可以通过以下方法优化内存分配: 使用默认构造函数和拷贝构造函数:如果类没有复杂的资源管理,可以使用编译器生成的默认构造函数和拷贝构造函...

  • C++构造函数支持委托构造吗

    C++构造函数支持委托构造吗

    是的,C++ 构造函数支持委托构造。委托构造是指一个构造函数可以调用同一个类中的另一个构造函数,从而避免代码重复。委托构造在 C++11 中引入,使用 this 指针实...

  • C++构造函数怎样实现默认初始化

    C++构造函数怎样实现默认初始化

    在C++中,构造函数可以通过不定义任何参数来实现默认初始化。当创建一个对象时,如果未提供任何构造函数参数,编译器将自动生成一个默认构造函数。这个默认构造函...

  • C++构造函数能调用虚函数吗

    C++构造函数能调用虚函数吗

    在 C++ 中,构造函数不能直接调用虚函数。当创建一个类的实例时,首先会调用该类的构造函数,然后才会初始化基类和成员对象。在这个过程中,虚函数尚未被正确初始...