我在 NSMutableArray 上收到此错误:
-[Not A Type release]: message sent to deallocated instance 0x1006e29c0
它发生在这一行:
[_array removeAllObjects];
现在,我明白错误的含义,但不明白为什么会在这种情况下发生。
我在上面的行之前添加了一个 NSLog,如下所示:
NSLog(@"%@", [_array class]);
这可以正常执行并具有正确的行为,这是日志:
2013-03-13 11:19:27.366 App[66921:303] __NSArrayM
2013-03-13 11:19:27.367 App[66921:303] *** -[Not A Type release]: message sent to deallocated instance 0x1006e29c0
所以在删除它之前似乎没有被释放..
即使我删除了 removeAllObjects 调用并将其替换为下面的行,我仍然会收到相同的错误。
_array = [[NSMutableArray alloc] init];
我在代码的其他地方所做的只是调用 [_array addObject:...]
_array 是一个强大的属性:
@property (strong) NSMutableArray *array;
数组首先在 init 方法中初始化。
编辑:我将 AXUIElementRefs 添加到此数组中,如下所示:
[_array addObject:(__bridge_transfer id)elementRef];
我认为 __bridge_transfer 将其带到了 ARC,而我不需要管理任何这些?
可能是什么问题呢?
更新:这是一个示例项目:http ://users.telenet.be/prullen/AXMemory.zip
这是一个工作项目,因为我使用的是 __bridge 而不是 __bridge_transfer。
这个项目包含一个简单的循环,一遍又一遍地做同样的事情。这是为了证明仅使用 __bridge,AXUIElementRefs 永远不会被释放。他们留在记忆中。这也是我在 Instruments profiler 中看到的。您还可以通过活动监视器看到内存使用量每隔几秒增加一次。
AXUIElementRefs 是通过 AXUIElementCopyMultipleAttributeValues 获得的 - 所以我会假设我拥有它们的所有权?然而,更改为 __bridge_transfer 会导致上述错误。
如果有人可以看看这个并让我知道我做错了什么,那将不胜感激。
我通过以下语句获得了一组属性:(第 60 行)。
AXUIElementCopyMultipleAttributeValues(frontWindowRef, attributes,0,&attributeValues);
第 110 行我分配了 AXUIElement(循环遍历 children 数组):
element = CFArrayGetValueAtIndex(childrenArrayRef, i);
第 112 行是我将 AXUIElementRef 添加到数组的位置:
[_array addObject:(__bridge id)(element)];
如果超过 500 个元素,我将第 36 行清空:
if ([_array count] > 500) {
[_array removeAllObjects];
}