0

我创建了一个共享库,我在另一个应用程序中使用它。共享库的核心功能之一是检查正在泄漏的对象的基类。

库中的代码如下:

// 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() 函数,输出也会将所有对象报告为“未命名的类”。

是否不可能跨共享库边界进行抽象?

4

1 回答 1

1

抽象方法也必须是虚拟的:virtual const char *getClassName() const = 0;

于 2013-06-09T19:36:28.627 回答