多线程技术 —— 通过并发提高程序的整体性能。
进程 - 应用程序,负责开辟一块内存区域,供应用程序执行
每一个进程都默认有一个“主线程”线程 - 要执行的任务流
当有耗时操作时,可能需要在后台新建一个子线程,来单独处理这些耗时的操作,待操作完成之后,再更新UI界面。 如果不放在其他线程执行,会“阻塞”住主线程的执行,影响用户体验。注意:所有界面UI的更新操作,都必须在主线程上完成!
提问:一般的应用程序最多能开多少条线程?回答:尽可能少得开线程,只有那些消耗时间,影响用于体验的操作,才会放到后台线程中执行,通常一个应用程序的子线程不应该超过20。
无论使用哪种多线程技术都可以使用
[NSThread currentThread]跟踪查看当前执行所在的线程情况。 num = 1表示在主线程上执行的任务 ================================================================1. NSObject多线程技术
1> 使用performSelectorInBackground可以开启后台线程,执行selector选择器选择的方法 2> 使用performSelectorOnMainThread可以重新回到主线程执行任务,通常用于后台线程更新界面UI时使用 3> [NSThread sleepForTimeInterval:1.0f]; 让当前线程休眠,通常在程序开发中,用于模拟耗时操作,以便跟踪不同的并发执行情况! 但是:在程序发布时,千万不要保留此方法!不要把测试中的代码交给客户,否则会造成不好的用户体验。 提示:使用performSelectorInBackground也可以直接修改UI,但是强烈不建议使用。 注意:在使用NSThread或者NSObject的线程方法时,一定要使用自动释放池,否则容易出现内存泄露。 ================================================================ 2. NSThread的多线程技术,仅了解即可,使用极少! 1> 类方法直接开启后台线程,并执行选择器方法 detachNewThreadSelector 2> 成员方法,在实例化线程对象之后,需要使用start执行选择器方法 initWithTarget 对于NSThread的简单使用,可以用NSObject的performSelectorInBackground替代 同时,在NSThread调用的方法中,同样要使用autoreleasepool进行内存管理,否则容易出现内存泄露。 ================================================================ 3. NSOperation,面向对象的多线程技术 1> 使用步骤: 1) 实例化操作 a) NSInvocationOperation b) NSBlockOperation 2) 将操作添加到队列NSOperationQueue即可启动多线程执行 2> 更新UI使用主线程队列 [NSOpeationQueue mainQueue] addOperation ^{}; 3> 操作队列的setMaxConcurrentOperationCount 可以设置同时并发的线程数量! 提示:此功能仅有NSOperation有! 4> 使用addDependency可以设置任务的执行先后顺序,同时可以跨操作队列指定依赖关系 提示:在指定依赖关系时,注意不要循环依赖,否则不工作。 ================================================================ 4. GCD,C语言 GCD就是为了在“多核”上使用多线程技术 1> 要使用GCD,所有的方法都是dispatch开头的 2> 名词解释 global 全局 queue 队列 async 异步 sync 同步 3> 要执行异步的任务,就在全局队列中执行即可 dispatch_async 异步执行控制不住先后顺序 4> 关于GCD的队列 全局队列 dispatch_get_global_queue 参数:优先级 DISPATCH_QUEUE_PRIORITY_DEFAULT 始终是 0 串行队列 dispatch_queue_create("myQueue", DISPATCH_QUEUE_SERIAL); 是创建得到的,不能直接获取 主队列 dispatch_get_main_queue 5> 异步和同步与方法名无关,与运行所在的队列有关! 提示:要熟悉队列于同步、异步的运行节奏,一定需要自己编写代码测试! 同步主要用来控制方法的被调用的顺序