我已经减少了这个易于编译的代码的泄漏问题,该代码在CTFontCreateWithGraphicsFont
使用和发布ct_font
之后显示,将留下额外的cg_font
引用。这是一个内部Apple引用计数问题,还是我遗漏了一些问题,比如必须加倍发布cg_font
或更改版本的顺序?感谢。
#include <stdio.h>
#include <stdlib.h>
#include <ApplicationServices/ApplicationServices.h>
int main(int argc, char **argv) {
FILE *f = fopen("/Library/Fonts/Tahoma.ttf", "rb");
fseek(f, 0, SEEK_END);
long fsize = ftell(f);
fseek(f, 0, SEEK_SET);
char* font = (char*)malloc(fsize);
fread(font, fsize, 1, f);
fclose(f);
CGDataProviderRef provider = CGDataProviderCreateWithData(NULL, font, fsize, NULL);
CGFontRef cg_font = CGFontCreateWithDataProvider(provider);
CTFontRef ct_font = CTFontCreateWithGraphicsFont(cg_font, 36., NULL, NULL);
CGDataProviderRelease(provider);
//
CFRelease(ct_font);
CFRelease(cg_font);
printf("ct_font: %d\ncg_font: %d\n", (int)CFGetRetainCount(ct_font), (int)CFGetRetainCount(cg_font));
free(font);
return 0;
}
编译并运行后的结果:
ct_font:-1
cg_font:1
答案 0 :(得分:2)
保留CGFont
发生在TInMemoryBaseFont
构造函数中:
#0 0x00007fff8928e4d0 in CFRetain ()
#1 0x00007fff86472906 in TInMemoryBaseFont::TInMemoryBaseFont(CGFont*) ()
#2 0x00007fff864728b8 in CTFontDescriptor::CTFontDescriptor(CGFont*, is_inmemory_t const&) ()
#3 0x00007fff8646cb30 in TDescriptorSource::CopyDescriptor(CGFont*, __CFDictionary const*) const ()
#4 0x00007fff8646c99a in TFont::InitDescriptor(CGFont*, __CTFontDescriptor const*) ()
#5 0x00007fff8646c7b4 in TFont::TFont(CGFont*, double, CGAffineTransform const*, __CTFontDescriptor const*) ()
#6 0x00007fff8646c775 in CTFontCreateWithGraphicsFont ()
在发布CTFont
时,它与发行版不匹配,可能是因为TInMemoryBaseFont
析构函数从未被调用(原因不明)。
这不是一个解决方案,但可能会帮助有人进一步调试问题。