我想问一下关于MKReverseGeocoder的内存管理,在iOS4.3之前,我一直使用下面的代码,分配MKReverseGeocoder,然后根据需要在reverseGeocoder:didFindPlavemark或reverseGeoCoder:didFailWithError中释放它。
然而,在iOS4.3中,我得到了EXC_BAD_ACCESS,而且它似乎来自于reverseGeocoder:didFailWithError的发行版。如果有人能为我指出正确的方向,我会非常感激,我可以使用autoRelease吗,这会让geoCoder停留足够长的时间让代理完成它的工作吗?
// ALLOC & START
MKReverseGeocoder *myGeocoder = [[MKReverseGeocoder alloc] initWithCoordinate:[lastGoodLocation coordinate]];
[myGeocoder setDelegate:self];
[myGeocoder start];。
// DID FIND
- (void)reverseGeocoder:(MKReverseGeocoder *)geocoder didFindPlacemark:(MKPlacemark *)placemark {
NSLog(@"GEOCODE: didFindPlacemark");
[self createLocation:placemark];
[geocoder release];
}。
// DID FAIL
- (void)reverseGeocoder:(MKReverseGeocoder *)geocoder didFailWithError:(NSError *)error {
NSLog(@"GEOCODE: didFailWithError");
[self createLocation:nil];
[geocoder release];
}发布于 2011-03-18 00:05:27
经过一番搜索,我认为解决方案可能是设置一个iVar来容纳MKReverseGeocoder。这样,我可以使用自动释放,同时仍然确保iVar将保持geoCoder,直到下一次设置iVar。有趣的是,上面的代码只从reverseGeocoder:didFailWithError生成一个EXC_BAD_ACCESS,而不是从reverseGeocoder:didFindPlacemark生成。我还检查了保留计数(是的,我知道它不可靠,但我想看看),在发布之前(崩溃),两个方法都报告保留计数为1。我唯一能猜到的是,当我发布时,地理编码的对象可能仍然在某个地方被使用。在一个方法中分配并使用回调中的指针释放,也会让人感觉很混乱。
@property(nonatomic, retain)MKReverseGeocoder geoCoder;。
[self setGeoCoder:[[[MKReverseGeocoder alloc] initWithCoordinate:coord] autorelease]];
[[self geoCoder] setDelegate:self];
[[self geoCoder] start];https://stackoverflow.com/questions/5299557
复制相似问题