NSURLConnection和NSRunLoop

本文介绍如何避免在iOS应用中使用NSURLConnection时主线程因执行长时间任务而阻塞的问题。通过调整NSURLConnection的初始化方式,并设置适当的run loop模式,确保应用响应性和异步请求的正常处理。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >


主线程中创建一个NSURLConnection并异步执行

[self performSelectorOnMainThread:@selector(start) withObject:nil waitUntilDone:YES];
- (void)start
{
    //step 1:请求地址
    NSURL *url = [NSURL URLWithString:@"www.2cto.com"];
    //step 2:实例化一个request
    NSURLRequest *request =[NSURLRequest requestWithURL:url cachePolicy:NSURLRequestUseProtocolCachePolicy timeoutInterval:30.0];
    //step 3:创建链接
    self.connection = [[NSURLConnection alloc] initWithRequest:request delegate:self];//直接运行了
    if (self.connection) {
        NSLog(@"链接成功");
    }else {
        NSLog(@"链接失败");
    }
}

问题:
当前线程是主线程
创建的NSURLConnection实例运行在主线程,主线程有一个运行的runloop实例来支持NSURLConnection的异步执行,
此时runloop的运行模式为NSDefaultRunLoopMode,这种mode下,如果主线程执行拖动操作,runloop不处理NSURLConnection的回调事件,
因为拖动操作发生过程中,使当前线程的runloop运行在UITrackingRunLoopMode模式下,这种模式下的runloop会暂定处理其他事件(异步请求回调、timer事件等)。


解决方法,修改代码为:

[self performSelectorOnMainThread:@selector(start) withObject:nil waitUntilDone:YES];
- (void)start
{
    //step 1:请求地址
    NSURL *url = [NSURL URLWithString:@"www.2cto.com"];
    //step 2:实例化一个request
    NSURLRequest *request =[NSURLRequest requestWithURL:url cachePolicy:NSURLRequestUseProtocolCachePolicy timeoutInterval:30.0];
    //step 3:创建链接
    self.connection = [[NSURLConnection alloc] initWithRequest:request delegate:self startImmediately:NO];//暂时不运行
    [connection scheduleInRunLoop:[NSRunLoop currentRunLoop] forMode:NSRunLoopCommonModes];//用NSRunLoopCommonModes
    [connection start];    
    if (self.connection) {
        NSLog(@"链接成功");
    }else {
        NSLog(@"链接失败");
    }
}





评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值