• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    迪恩网络公众号

ios - dispatch_after 会阻塞 UI 吗?

[复制链接]
菜鸟教程小白 发表于 2022-12-13 10:53:43 | 显示全部楼层 |阅读模式 打印 上一主题 下一主题

我希望了解在调度内运行异步 NSURLConnection 是否有任何负面影响。我正在使用调度,因为它看起来比我的目的的计时器更干净。

调用是异步的,但我想确保使用 dispatch_after 不会阻塞 UI。有人可以帮助我了解 dispatch_after 是否会在这 10 秒内以任何方式阻止 UI/应用程序吗?谢谢!

int delaySeconds = 10;

dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(delaySeconds 
* NSEC_PER_SEC)), dispatch_get_main_queue(), ^{

    aURL = [NSURL URLWithString"http://google.com"];
    request = [NSMutableURLRequest requestWithURL:aURL
                                      cachePolicy:NSURLRequestUseProtocolCachePolicy
                                  timeoutInterval:60.0];

    [NSURLConnection sendAsynchronousRequest:request queue:
    [NSOperationQueue mainQueue] completionHandler:^(NSURLResponse *response) {

        //do something with response

    }];

});

附:我看过Does dispatch_after block the main thread?但我还是有点迷茫。



Best Answer-推荐答案


dispatch_after 中的代码在延迟后实际运行之前不会阻塞任何内容。然后在指定的队列上运行。

由于您指定了主队列,代码将在主 UI 线程上运行。但在延迟期间 UI 并未“阻塞”。

但是这个例子很糟糕。虽然 NSURLNSURLRequest 创建是在主线程上完成的,但请求的实际执行是异步完成的,因此主线程在请求​​期间不会被阻塞。直到完成处理程序被调用,你才再次回到主线程。但这是因为您为完成 block 指定了主队列,而不是因为 dispatch_after 正在主线程上完成。

所以这里唯一真正在主线程上运行的代码是 NSURLConnection 完成 block 。实际请求在后台完成(因为它是异步的)。主线程上的其他代码很简单。

在调度 block 运行之前的 delaySeconds 期间没有线程被阻塞。

关于ios - dispatch_after 会阻塞 UI 吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30630715/

回复

使用道具 举报

懒得打字嘛,点击右侧快捷回复 【右侧内容,后台自定义】
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

关注0

粉丝2

帖子830918

发布主题
阅读排行 更多
广告位

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap