我创建了一个共享库,我在另一个应用程序中使用它。共享库的核心功能之一是检查正在泄漏的对象的基类。
库中的代码如下:
// LeakCheck.hpp
#include <vector>
class LeakCheck
{
private:
static std::vector<LeakCheck*> objects;
public:
virtual const char *getClassName() const = 0;
LeakCheck();
~LeakCheck();
friend class LeakCheckMaster;
};
// LeakCheck.cpp
#include <iostream>
class LeakCheckMaster
{
~LeakCheckMaster()
{
if (LeakCheck::objects.size()>0) {
std::cerr << "Leaked objects:" << std::endl;
for (int i=0; i<LeakCheck::objects.size(); i++)
std::cerr << LeakCheck::objects[i]->getClassName() << std::endl;
}
}
} master;
std::vector<LeakCheck*> LeakCheck::objects;
LeakCheck::LeakCheck()
{
objects->push_back(this);
}
LeakCheck::~LeakCheck()
{
objects->remove(this);
}
测试应用程序将是:
#include "LeakCheck.hpp"
class Test : public LeakCheck
{
public:
const char *getClassName() const
{
return "Test";
}
};
int main()
{
Test *a = new Test();
return 0
}
但是,当我尝试链接应用程序时,我得到“对 LeakCheck::getClassName() 的未定义引用”。我确信我已经与共享库链接,因为其他功能可以工作。
这不是实际的代码。我试图只留下对问题至关重要的代码。希望我没有错过任何东西。
那么为什么会出现这个链接器错误呢?如果我将它从纯虚拟更改为返回“未命名类”。即使我已经实现了 getClassName() 函数,输出也会将所有对象报告为“未命名的类”。
是否不可能跨共享库边界进行抽象?