의 retainCount을 변경, 그래서 나는 관찰 세트 : 내가 내 클래스의 인스턴스가 자체의 속성을 관찰하는 것이 필요 오브젝트
[self addObserver:self forKeyPath:@"myProperty" options:NSKeyValueObservingOptionNew context:nil]
와의 dealloc에서
단순히 관찰자를 확인하고 제거 : 를- (void)dealloc
{
if ([self observationInfo])
{
[self removeObserver:self];
}
}
이 프로젝트는 ARC하에 있으며, iOS 6 SDK 이전의 모든 프로젝트는 정상적으로 작동합니다. 그러나 iOS 6 SDK를 사용하면 이 (가) dealloc
EX_BAD_ACCESS (해제 메시지가 할당 취소 된 인스턴스로 전송 됨) 이후에 개체 및 앱의 retainCount가 증가합니다.
이 코드의 잘못된 점은 무엇입니까? 그것은 애플의 BUG인가 내 것이냐?
thread #1: tid = 0x1f03, 0x016b60ab libobjc.A.dylib`objc_release + 27, stop reason = EXC_BAD_ACCESS (code=1, address=0xff000002)
frame #0: 0x016b60ab libobjc.A.dylib`objc_release + 27
frame #1: 0x016b6bd9 libobjc.A.dylib`(anonymous namespace)::AutoreleasePoolPage::pop(void*) + 555
frame #2: 0x02538468 CoreFoundation`_CFAutoreleasePoolPop + 24
frame #3: 0x0253cafd CoreFoundation`__CFRunLoopRun + 1933
frame #4: 0x0253bf44 CoreFoundation`CFRunLoopRunSpecific + 276
frame #5: 0x0253be1b CoreFoundation`CFRunLoopRunInMode + 123
frame #6: 0x024f07e3 GraphicsServices`GSEventRunModal + 88
frame #7: 0x024f0668 GraphicsServices`GSEventRun + 104
frame #8: 0x0022e65c UIKit`UIApplicationMain + 1211
frame #9: 0x00001efd MyProjects`main + 141 at main.m:16
정보가 충분하지 않습니다. 첫째,'retainCount'는 도움이되지 않는 쓸모가 없습니다. 둘째, 충돌이 있으면 백 트레이스를 게시하십시오. – bbum
stacktrace를 추가합니다. 자동 복구 풀만 청소합니다. 내 견해는 observationInfo를 얻는 데있어서의 문제입니다. [self observationInfo]를 호출하면 self.retainCount가 변경됩니다 (iOS 6 SDK에서만 증가). 나는 그것이 매우 이상한 행동이라고 생각한다. – Killer
단순히 설정자를 무시하는 대신 속성을 관찰하는 이유가 있습니까? – jrturton