您的设计是不正确的。
由于您正在执行异步调用,因此无法在方法中同步返回值。
completionHandler
是一个将来会被调用的块,因此您必须在调用块时更改代码的结构以处理结果。
例如,您可以使用回调:
- (void)findCityOfLocation:(CLLocation *)location {
geocoder = [[CLGeocoder alloc] init];
typeof(self) __weak weakSelf = self; // Don't pass strong references of self inside blocks
[geocoder reverseGeocodeLocation:location completionHandler:^(NSArray *placemarks, NSError *error) {
if (error || placemarks.count == 0) {
[weakSelf didFailFindingPlacemarkWithError:error];
} else {
placemark = [placemarks objectAtIndex:0];
[weakSelf didFindPlacemark:placemark];
}
}];
}
- (void)didFindPlacemark:(CLPlacemark *)placemark {
// do stuff here...
}
- (void)didFailFindingPlacemarkWithError:(NSError *)error {
// handle error here...
}
或块(我通常喜欢)
- (void)findCityOfLocation:(CLLocation *)location completionHandler:(void (^)(CLPlacemark * placemark))completionHandler failureHandler:(void (^)(NSError *error))failureHandler {
geocoder = [[CLGeocoder alloc] init];
[geocoder reverseGeocodeLocation:location completionHandler:^(NSArray *placemarks, NSError *error) {
if (failureHandler && (error || placemarks.count == 0)) {
failureHandler(error);
} else {
placemark = [placemarks objectAtIndex:0];
if(completionHandler)
completionHandler(placemark);
}
}];
}
//usage
- (void)foo {
CLLocation * location = // ... whatever
[self findCityOfLocation:location completionHandler:^(CLPlacemark * placemark) {
// do stuff here...
} failureHandler:^(NSError * error) {
// handle error here...
}];
}
我现在看到的这个,谢谢,我希望我能对此答案投票! – maxmclau
不客气。即使你不能投票的答案,你可以通过选择分数下的勾号接受它;) –
对不起,我不知道只能检查一个单一的答案。固定 – maxmclau