我有一个类作为 NSMutableDictionary 的子类(主要是通过委托(delegate)),因为我们有一些自定义接口(interface)包裹在字典周围。运行 ios 泄漏工具时,它会将我的 keyEnumerator 方法识别为 NSFastEnumerationEnumerator 对象的泄漏源。
这是我作为封装的 NSMutableDictionary 的委托(delegate)的 keyEnumeration 方法。
- (NSEnumerator*) keyEnumerator {
return [dictionary keyEnumerator];
}
泄漏的回溯总是显示一个枚举器作为源:
- (void) someMethod {
for (NSString *key in myWrappedDictionary) { ... }
}
这是一个典型的回溯:
calloc
class_createInstance
__CFAllocateObject2
-[__NSCFDictionary keyEnumerator]
-[WrappedDictionary keyEnumerator]
-[NSDictionary countByEnumerating...
-[SomeClass someMethod]
我正在寻找我的一行代码中的解决方法或缺陷。我正在使用 ARC。
一个示例类如下所示。调用 [WrappedDictionary createLeaks] 将创建 9 个泄漏。
@interface WrappedDictionary : NSMutableDictionary {
NSMutableDictionary *dictionary;
}
- (id) init;
- (NSUInteger) count;
- (NSEnumerator*) keyEnumerator;
- (void)setObjectid)anObject forKeyid)key;
@end
@implementation WrappedDictionary
- (id) init {
dictionary = [NSMutableDictionary new];
return self;
}
- (NSUInteger) count { return [dictionary count]; }
- (NSEnumerator*) keyEnumerator {
return [dictionary keyEnumerator];
}
- (void)setObject: anObject forKey:key {
[dictionary setObject:anObject forKey: key];
}
+ (void) createLeaks {
for (int i=0; i < 10; i++) {
WrappedDictionary *dict = [WrappedDictionary new];
[dict setObject"1" forKey"1"];
[dict setObject"2" forKey"2"];
[dict setObject"3" forKey"3"];
for (NSString *key in dict) {
NSLog(@"key=%@",key);
}
}
}
@end
请记住,泄漏工具只是显示泄漏的内存块分配的位置。这并不意味着分配点是泄漏的来源。更可能的泄漏源在 someMethod
中,或者在 someMethod
的调用者中,特别是如果您将其放入 ivar 然后对整个对象进行保留循环.
关于objective-c - 从 NSMutableDictionary 派生时,FastEnumeration 中的明显内存泄漏,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9795683/
欢迎光临 OStack程序员社区-中国程序员成长平台 (https://ostack.cn/) | Powered by Discuz! X3.4 |