如何在覆盖具有错误可见性的虚拟方法时得到警告
How to be warned when overriding a virtual method with wrong visibility
当重写虚方法时,我注意到当我在可见性上犯错误时(作为公共方法重写的受保护方法),编译器不会警告我。
在c++中是有效的,但通常是错误的。
例如:#include <iostream>
class Base
{
protected:
virtual void ProtectedMethod(void)
{
std::cout << "Base::ProtectedMethod" << std::endl;
}
};
class Derived : public Base
{
public:
virtual void ProtectedMethod(void)
{
std::cout << "Derived::ProtectedMethod" << std::endl;
}
};
int main(int, char* [])
{
Derived d;
d.ProtectedMethod();
}
我试着用gcc和clang编译,用-Wall -Wextra,没有运气。我在这段代码上运行了CppCheck,仍然没有运气。
什么工具可以帮我检测到这个?我需要修复我正在开发的一个库的全部源代码。
Inspirel允许您定义自己的规则:http://www.inspirel.com/vera/
我找到了一个使用标签的解决方案。
CTags可以解析c++并将信息转储到文件中。
使用以下选项:
$CTAGS -f $TAGFILE --fields=fkstia --c++-kinds=+p -R $SOURCES
我可以用一种容易解析的格式得到所有需要的信息。
通过几个grep
命令管道$TAGFILE
,我可以验证已知函数名是否具有预期的可见性,并对相关文件发出警告。
下面是一个从标签输出中提取信息的bash代码片段:
#!/bin/bash
function check_method {
echo "Checking $1 (should be $2 and is not)"
cat $TAGFILE | grep "^$1 " | grep "access" | grep -v "access:$2" | cut -f 2
echo
}
# will warn anytime a method called ProtectedMethod is not protected
check_method ProtectedMethod protected
相关文章:
- 用常见虚拟函数实现的任意组合来实现派生类的正确方法是什么
- 在模板基类中为继承类中的可选重写生成虚拟方法
- 跨 DLL 边界访问虚拟方法是否安全/可能?
- 是否可以使用基类非虚拟方法中的派生类虚拟方法?
- 如何编写 operator= 用于使用虚拟方法与非平凡成员的匿名联合
- 让编译器告诉什么确切的纯虚拟方法使结构抽象?
- 使用模板而不是虚拟方法的管道模式
- 派生类调用父类的方法,该方法调用重写的虚拟方法调用错误的方法
- 从纯虚拟类 (A) 派生的指针无法访问来自纯类 (B) 的重载方法
- 为什么调用没有正文的纯虚拟方法不会导致链接器错误?
- 出于什么目的,非虚拟方法将与C++一起使用?
- 为什么使用存储在虚拟方法表中的地址调用虚拟函数的函数会返回垃圾?
- 如何重写继承的嵌套类中存在的虚拟方法
- 私有虚拟方法有什么用?
- 派生类中纯虚拟基方法的专业化
- 基类可以声明虚拟方法但不定义它吗?仍然在派生类中定义
- googletest:测试基类具有纯虚拟方法的派生类时的核心转储
- 确保模拟的 GTest 方法覆盖虚拟方法
- 使用回调函数从构造函数调用虚拟/派生方法的替代方法?
- 如何调用孩子的方法:虚拟关键字不起作用