У меня есть подкласс с двумя методами:
- (void) aPostRequest:(NSString *) urlStr andJSON:(NSMutableDictionary*) jsonDict completion:(void (^)(NSDictionary *, NSError *))completion
{
NSError *error = nil;
NSURLSessionConfiguration *configuration = [NSURLSessionConfiguration defaultSessionConfiguration];
NSURLSession *session = [NSURLSession sessionWithConfiguration:configuration];
NSURL *url = [NSURL URLWithString:urlStr];
NSMutableURLRequest *request = [NSMutableURLRequest requestWithURL:url cachePolicy:NSURLRequestUseProtocolCachePolicy timeoutInterval:60.0];
[request setHTTPMethod:@"POST"];
[request addValue:@"application/json" forHTTPHeaderField:@"Content-Type"];
[request addValue:@"application/json" forHTTPHeaderField:@"Accept"];
// Set up the post data
NSData *postData = [NSJSONSerialization dataWithJSONObject:jsonDict options:0 error:nil];
[request setHTTPBody:postData];
// dispatch_semaphore_t semaphore = dispatch_semaphore_create(0);
NSURLSessionDataTask *postDataTask = [session dataTaskWithRequest:request completionHandler:^(NSData *data, NSURLResponse *response, NSError *error)
{
if (!error)
{
// convert the NSData response to a dictionary
NSDictionary *dictionary = [NSJSONSerialization JSONObjectWithData:data options:0 error:&error];
if (error)
{
// There is a parse error
completion(nil, error);
}
else
{
// Success
completion(dictionary, nil);
}
}
else
{
// Error from the session
completion(nil, error);
}
// dispatch_semaphore_signal(semaphore);
}];
// dispatch_semaphore_wait(semaphore, DISPATCH_TIME_FOREVER);
[postDataTask resume];
}
И этот метод, который вызывает метод выше:
- (NSString *) verifyUnique
{
// JSON data
__block NSString *verifyUnique = nil;
// dispatch_semaphore_t semaphore = dispatch_semaphore_create(0);
// URL string
NSString *url = @"https://the-website-to-handle-this.com";
NSMutableDictionary *json = [[NSMutableDictionary alloc] init];
[json setValue:@"testing" forKey:@"name"];
[self aPostRequest:url andJSON:json completion:^(NSDictionary *response, NSError *error)
{
// dispatch_semaphore_signal(semaphore);
if (!error) {
} else {
verifyUnique = [response objectForKey:@"uniqueness"];
// return verifyUnique;
// dispatch_semaphore_signal(semaphore);
}
}];
// dispatch_semaphore_wait(semaphore, DISPATCH_TIME_FOREVER);
return verifyUnique;
}
Я вызываю функцию из другого класса контроллера представления и вызываю [thisClass verifyUnique];
и хочу, чтобы она ждала, пока не будет возвращен ответ. Прежде чем он был вызван в контроллере представления, пользовательский интерфейс обрабатывается индикатором активности, поэтому мы можем подождать. Как дождаться возврата обоих блоков завершения?
dataTaskWithRequest
иaPostRequest
используют этот шаблон, и мы все предполагаем, что ваш собственныйverifyUnique
делает то же самое. - person Rob   schedule 03.07.2016