当一个类的所有实例都被销毁时释放内存

freeing memory when all instances of a class are destroyed

本文关键字:实例 内存 释放 一个      更新时间:2023-10-16

我有一个字体类,它将使用sdl将字形从.ttf加载到openGL纹理。该类由每个字形的单独纹理组成,很明显会连续渲染它们以创建显示的文本。我认为将.ttf加载到sdl曲面,然后使用曲面像素数据生成openGL纹理的成本很高。因此,我的程序有一个KText类,它有一个成员:static std::vector<Font*> OpenedFonts;

当继承了KText的新项目尝试打开字体时,我会扫描矢量以查找打开的字形,然后只返回一个指向打开的字形的指针,并只对该文本的所有实例使用已制作的纹理(大小/名称/颜色)。

代码是

bool KText::LoadFont() {
    _Font = CheckOpenedFonts(); //_Font is KFont* pointer
    if(_Font == NULL) {
        _Font = new KFont;
        _Font->LoadFont();
    }
    if(_Font == NULL) return false;
    return true;
}

显然,并不是每次我都会打开一个新字体,所以在析构函数中,我不想简单地使用delete _Font。因为这两个原因:有另一个KText对象指针指向同一组字形,最好将它们保存在内存中,直到程序终止,以防创建另一个对象并尝试使用该字体。

有没有办法等到KFont的所有实例都离开作用域?

谢谢!

解决方案是:

class KText {
private:
    static int TextCnt;
public:
    KText();
    ~KText();
};
//Implementation
static int KText::TextCnt = 0;
KText::KText() {
   TextCnt++;
}
KText::~KText() {
   TextCnt--;
   if(TextCnt < 1) {
       OpenedFonts* t = FntPnter; //FntPnter is a head pointer to the linked list of fonts
       while(t != NULL ) {
           FntPnter = t->Next;
           delete t;
           t = FntPnter;
        }
    }
}

您可以在KFont中创建一个静态整数成员,比如说static int KFontCnt;,它是KFont对象的数量。然后在KFont构造函数中增加KFontCnt,在KFont析构函数中减少。当它在析构函数中达到0时,您可以释放所有KFont实例。