一直在思考,每次异步请求都会创建一个新线程,如果我同时发100个异步请求,这样会导致我的内存爆满,应用程序奔溃,因为iOS对开线程有着约束,不能开很多个线程,这就要求我们必须对异步请求进行控制,我一直都试图将异步请求放在NSOperationque多线程中,让队列去进行管理,可是这样会造成开更多的线程,并且不能直接对异步请求进行诸如[queue addOperation:operation]语法的实现。因为从SDWebImage的原理看出,它就是用了多线程并且使用了NSURLConnection进行了进度监听,我知道我的想法我的思路一定是对的,但是怎么实现呢,前后查了很多资料也请教了很多朋友,但是无奈他们对多线程的理解并不像我以为的那么深入。今晚,当我看到自定义NSOperation实现的那一刻,我就知道了。原来我的思路是对的,只要加入这样一行代码,就能将我的思路想法通通实现,解法1:NSOperationQueue *queue=[[NSOperationQueue alloc]init];[conn setDelegateQueue:queue]。
解法2: //循环的目的:让runloop一直运行, 造成当前线程阻塞, 保持线程不结束,自定义子线程: runloop默认不开启
while ( !isFinished ) {
[[NSRunLoop currentRunLoop] runMode:NSDefaultRunLoopMode beforeDate:[NSDate distantFuture]];
}
再通过
[[NSOperationQueue mainQueue] addOperationWithBlock:^{
{
NSLog(@"%@",[NSThread currentThread]);
}
}];
终于等到你,还好的没放弃。
解决了最近半个月的技术难题。自定义NSOperation瞬间爆炸
原文:http://www.cnblogs.com/xsiOS/p/5081314.html