隐藏规则-参数/返回类型必须相同吗?
Hiding rule- do the arguments/return type have to be the same?
我有几个问题/关于隐藏的一般问题?
基类有一个函数:f()派生类现在声明虚函数f()
如果派生函数是const会发生什么?这不是隐藏吗?
如果返回类型不同怎么办?
参数不一致?
一个是静态的,另一个不是?
只是想知道两个函数之间的哪些差异会导致隐藏/不会导致隐藏
隐藏的是名字,而不是签名。
重要的事先说
隐藏指的是如果在派生类中重写基类函数,那么在派生类中定义的原始基类方法将被隐藏。也就是说,如果你需要从基类访问你的函数定义,那么你需要在你的代码中有这是不隐藏的:
using baseClass::functionName();
Const—如果你定义一个函数两次,一次使用Const,另一次不使用Const,它们是不同的。Scott Mayers的《effective c++》一书中有一章很好地解释了const和non - const,我建议你读一下,以彻底理解。
你不能通过有不同的返回类型来覆盖一个函数,它可能会给出编译时的错误,说明它是模糊的-测试它,以确保。
你可以通过不同的参数列表来重载一个函数,这就是重载函数的方式。
如果你在override和overload之间感到困惑,那么我建议你也仔细阅读一下。简而言之,重载是指在同一作用域中有两个具有不同参数列表的函数,而重写是指在具有相同参数列表的派生类中重新定义基类虚函数。
相关文章:
- 如何获取std::result_of函数的返回类型
- 奇怪的结构&GCC&clang(void*返回类型)
- 如何建立使用模板函数的lambda函数的尾部返回类型
- 为什么与常规GCC不同,即使有"学究性错误",MinGW-GCC也能容忍丢失的返回类型
- 在没有定义返回类型的函数中返回布尔值,并将结果保存在无错误的char编译中-为什么
- 特征::矩阵<双精度,1,3> 结构类型函数中的返回类型函数
- 函数作为模板参数,是否对返回类型强制约束
- C++中函数的向量返回类型引发错误
- 检查函数返回类型是否与STL容器类型值相同
- 为什么返回类型中需要typename?C++
- <Windows>为什么 std::thread::native_handle 返回类型为"long long unsigned int"的值,而不是 void*(又名 HANDLE)?
- 警告:在函数返回类型 [-Wignore 限定符] 时忽略类型限定符
- 为什么 c++(g++) 不允许模板返回类型和函数名称之间有空格?
- 为什么返回类型的'const'限定符对标有 __forceinline/内联的函数没有影响?
- 推导 std::vector::back() 的返回类型
- 在 c++ 中将函数返回类型指定为模板参数
- 使用 SWIG 更改生成的 CS 函数中的返回类型
- QtQuick - qml:28:错误:未知方法返回类型:自定义类型
- 本地类规则是否与c++14返回类型推导一致
- 隐藏规则-参数/返回类型必须相同吗?