gpt4 book ai didi

ios - AFHTTPClient 成功和失败 block 中的 CFRunLoopRunInMode()

转载 作者:行者123 更新时间:2023-11-28 22:35:56 24 4
gpt4 key购买 nike

我正在尝试使用 CFRunLoopRunInMode() 来避免在 [AFHTTPClient getPath:...] 完成 block 中返回。

我的代码如下:

NSLog(@"start");
__block BOOL someCondition = NO;
AFHTTPClient *client = [[AFHTTPClient alloc] initWithBaseURL:[NSURL URLWithString:@"http://domain.com"]];
[client getPath:@"my/path" parameters:nil success:^(AFHTTPRequestOperation *operation, id responseObject) {
NSLog(@"success");
} failure:^(AFHTTPRequestOperation *operation, NSError *error) {
dispatch_async(dispatch_get_main_queue(), ^{
NSLog(@"async log");
someCondition = YES;
});
while (!someCondition) {
CFRunLoopRunInMode(kCFRunLoopDefaultMode, 0.5, YES);
}
NSLog(@"failure");
}];

我预计输出为:

start
async log
failure

但我只得到:

start

CFRunLoopRunInMode() 返回 kCFRunLoopRunHandledSource,但调度队列从不执行提交的 block 。如果我在完成 block 之外运行相同的代码,则输出符合预期。

我不明白为什么从完成 block 运行时调度队列没有被处理。

有人可以解释一下为什么会发生这种情况吗?

最佳答案

I cannot figure out why the dispatch queue is not processed when run from completion blocks.

因为您没有“运行”调度队列(不存在“运行”调度队列这样的事情)。你运行了运行循环。调度队列是相关的,但又是另一回事。在串行队列(如 main)上一次只能运行一个 block 。在您的区 block 完成之前,无法安排其他区 block 。 GCD 中没有 API 可以规避这一点。这通常是一件非常好的事情,因为它为运行循环操作中并不总是存在的队列操作提供了确定性。

关于ios - AFHTTPClient 成功和失败 block 中的 CFRunLoopRunInMode(),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16024169/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com