派生类使用或不带 "virtual" 前缀重写基类的虚函数之间有什么区别?
What's the difference between the Derived class override the base class's virtual function with or not with a "virtual" prefix?
class A
{
virtual void funcion()
{
//...
}
}
class B:public A
{
//1:virtual void function();
//2:void function();
}
1和2有什么区别?还是一样?
它们是一样的。在基类中声明virtual
的函数在整个继承链中virtual
。
我发现为了清楚起见,添加virtual
很有用(通常情况下,这些类不在同一文件中(。
它们完全相同。在基类中声明函数virtual
后,默认情况下,从该函数继承的任何类也将将该函数声明为virtual
。
相关文章:
- 编译器如何在使用SFINAE的函数和标准函数之间确定两者是否可行
- 填充上编译器生成的复制构造函数之间的不一致
- 为什么不允许成员函数和非成员函数之间的函数重载?
- 如何在"push_*()"和"emplace_*()"函数之间进行选择?
- 仅具有运算符()的结构和普通函数之间的实际区别
- 当两者都调用时,删除和析构函数之间的区别?
- Release() 和析构函数之间的区别?
- 调用 "project" 函数和调用 DLL 函数之间的区别
- C++模板和非模板函数之间的重载解析
- std::shared_ptr 和 std::unique_ptr 构造函数之间的不对称
- C++ 和 Lua 函数之间的交互与 3D 矢量参数
- 在结构函数之间传递文件路径 C++ 编辑:修复LNK2019错误
- 在C++同名的顶级函数之间进行选择
- 在成员函数之间传递const变量为数组的索引
- Helgrind 报告了使用 Singleton 及其构造函数之间可能存在的竞争
- 函数模板和函数之间奇怪的不一致"normal"
- 在c#和c函数之间传递值和指针
- 在C++中调用 malloc() 与"operator new"函数之间的实现差异
- 在函数之间传递相同的数组
- C++编译错误是由于使用 std::move 时运动构造函数与其他非运动构造函数之间的冲突