我得到一个编译器警告,我不明白在这种情况下.当我从以下代码编译“Child.cpp”时. (不要奇怪:我把我的班级声明从最低限度上解除了,所以内容不会很有意义,但你会更快地看到问题).我在
VisualStudio2003和
VisualStudio2008的最高警戒级别得到警告.
AbstractClass.h:
#include <iostream> template<typename T> class AbstractClass { public: virtual void Cancel(); // { std::cout << "Abstract Cancel" << std::endl; }; virtual void Process() = 0; }; // Outside definition. If I comment out this and take the inline // definition like above (currently commented out),I don't get // a compiler warning. template<typename T> void AbstractClass<T>::Cancel() { std::cout << "Abstract Cancel" << std::endl; }
Child.h:
#include "AbstractClass.h" class Child : public AbstractClass<int> { public: virtual void Process(); };
Child.cpp:
#include "Child.h" #include <iostream> void Child::Process() { std::cout << "Process" << std::endl; }
警告
“Child”类派生自“AbstractClass”.在“AbstractClass”中有公共方法“AbstractClass :: Cancel()”.如果我定义方法在类的外部(如你看到的代码),我得到编译器警告…
AbstractClass.h(7) : warning C4505: ‘AbstractClass::Cancel’ : unreferenced local function has been removed
with [T=int]
…当我编译“Child.cpp”.我不明白这一点,因为这是一个公共功能,编译器不知道我以后是否引用这个方法.而且,最后,我引用这个方法,因为我在main.cpp中调用它,尽管这个编译器警告,如果我编译并链接所有文件并执行程序,这个方法是有效的:
//main.cpp #include <iostream> #include "Child.h" int main() { Child child; child.Cancel(); // Works,despite the warning }
如果我将Cancel()函数定义为inline(您将其看作是AbstractClass.h中的注释代码),那么我不会得到编译器警告.当然我的程序工作,但我想了解这个警告,还是这只是一个编译错误?
此外,如果不执行AbsctractClass作为模板类(在这种情况下仅用于测试目的),我也不会得到编译器警告…?
如果我做一个非虚拟函数,我没有得到非虚拟函数的编译警告,但是现在所有的答案都不包括虚拟的东西.尝试这个:
template<typename T> class AbstractClass { public: virtual void Cancel(); // { std::cout << "Abstract Cancel" << std::endl; }; virtual void Process() = 0; void NonVirtualFunction(); }; //... template<typename T> void AbstractClass<T>::NonVirtualFunction() { std::cout << "NonVirtualFunction" << std::endl; }
答案知道帮助我,但我不认为这个问题是完全回答的.