微信公众平台
![%E5%BE%AE%E4%BF%A1%E5%85%AC%E5%8F%B0%E5%8F%B7.jpg?raw=true]()
1 进程的五态模型
![%E8%BF%9B%E7%A8%8B%E4%BA%94%E6%80%81%E6%A8%A1%E5%9E%8B%E5%9B%BE.png?raw=true]()
2 线程
线程是进程的基本执行单元
进程中的所有的任务全部是在线程中完成
3 多线程任务执行方式
串行 一个任务一个任务执行
并行 多个任务同时执行
4 IOS创建多线程的方式
![ios%E5%88%9B%E5%BB%BA%E5%A4%9A%E7%BA%BF%E7%A8%8B%E6%96%B9%E5%BC%8F.png?raw=true]()
5 pThread
- (void)pThreadClickFunction{
pthread_t thread;
NSString *str = @"helloWorld";
int result = pthread_create(&thread, NULL, &demo, (__bridge void *)(str));
NSLog(@"over %d",result);
}
void *(demo)(void *param){
NSString *str = (__bridge NSString *)(param);
NSLog(@"%@",str);
return NULL;
}
6 NSThread
6.1 方法一
NSThread *thread = [[NSThread alloc] initWithTarget:self selector:@selector(threadFunction) object:@"alloc"];
thread.name = @"xiaosan";
thread.threadPriority=100;
thread.stackSize=512;
[thread start];
6.2 方法二
[NSThread detachNewThreadSelector:@selector(threadFunction) toTarget:self withObject:@"detach"];
6.3 方法三
[self performSelectorInBackground:@selector(threadFunction) withObject:@"perform"];
7 GCD
- GCD全称Grand Central Dispatch,我们通俗的翻译叫牛逼的中心调度
- GCD 在后端管理着一个线程池
- GCD会自动利用更多的CPU内核(比如双核、四核)
- GCD会自动管理线程的生命周期(创建线程、调度任务、销毁线程
7.1 任务执行的方式
dispatch_sync(globalQueue, ^{
});
dispatch_async(globalQueue, ^{
});
7.2 任务执行的顺序
dispatch_queue_t globalQueue =dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0);
dispatch_queue_t mainQueue = dispatch_get_main_queue();
dispatch_queue_t customMain = dispatch_queue_create("com.example.MyQueue", DISPATCH_QUEUE_SERIAL);
dispatch_queue_t customGlobal = dispatch_queue_create("com.example.MyQueue", DISPATCH_QUEUE_CONCURRENT);
7.3 队列组
dispatch_queue_t queue = dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0);
dispatch_group_t group = dispatch_group_create();
dispatch_group_async(group, queue, ^{
NSLog(@"开始执行1");
});
dispatch_group_async(group, queue, ^{
NSLog(@"开始执行2");
});
dispatch_group_async(group, queue, ^{
NSLog(@"开始执行3");
});
dispatch_group_notify(group, queue, ^{
NSLog(@"全部执行完成,必须在主线程更新UI!!!");
dispatch_async(dispatch_get_main_queue(), ^{
NSLog(@"主线程更新UI完成。");
});
});
8 NSOperation
- 封装了 GCD 实现多线程编程
-
使用 NSOperation 实现多线程编程的方式有3种:
(1)使用NSOperation的子类 NSInvocationOperation
(2)使用NSOperation的子类 NSBlockOperation
(3)自定义子类继承NSOperation,实现内部相应的⽅法
8.1 NSInvocationOperation方式
NSInvocationOperation *operation=[[NSInvocationOperation alloc]initWithTarget:self selector:@selector(threadFunction) object:nil];
[operation start];
8.2 NSBlockOperation 方式
NSBlockOperation *blockOperation=[NSBlockOperation blockOperationWithBlock:^{
NSLog(@"NSBlockOperation------%@",[NSThread currentThread]);
}];
[operation start];
8.3 上述两种 实现方式说明
- 操作对象默认在主线程中执行,只有添加到队列中才会开启新的线程。即默认情况下,如果操作没有放到队列中queue中,都是同步执行。只有将NSOperation放到一个NSOperationQueue中,才会异步执行操作
- 如果将NSOperation添加到NSOperationQueue(操作队列)中,系统会自动异步执行NSOperation中的操作
8.3.1 NSOperationQueue使用方法
NSOperationQueue * queue=[[NSOperationQueue alloc]init];
[queue addOperation:operation1];
[queue addOperation:operation2];
[queue addOperation:operation3];
[queue addOperationWithBlock:^{
NSLog(@"NSBlockOperation3--4----%@",[NSThread currentThread]);
}];
8.3.2 结合NSOperationQueue
NSInvocationOperation *operation1=[[NSInvocationOperation alloc]initWithTarget:self selector:@selector(test1) object:nil];
NSBlockOperation *operation2=[NSBlockOperation blockOperationWithBlock:^{
NSLog(@"NSBlockOperation3--1----%@",[NSThread currentThread]);
}];
[operation2 addExecutionBlock:^{
NSLog(@"NSBlockOperation3--2----%@",[NSThread currentThread]);
}];
NSOperationQueue * queue=[[NSOperationQueue alloc]init];
[queue addOperation:operation1];
[queue addOperation:operation2];
- 系统自动将NSOperationqueue中的NSOperation对象取出,将其封装的操作放到一条新的线程中执行。
- 上面的代码示例中,一共有三个任务,operation1有一个任务,operation2有两个任务。一共三个任务,经过测试发现系统开启了三条线程。通过任务执行的时间可以看出,这些任务是并行执行的。
8.4 自定义子类继承NSOperation 实现方式
#import <Foundation/Foundation.h>
#pragma mark-设置代理和代理方法
@class CustomOperation;
@protocol CustomOperationDelegate <NSObject>
-(void)customOperation:(CustomOperationDelegate*)operation didFished:(NSString *)string;
@end
@interface CustomOperation : NSOperation
@property(nonatomic,strong)id <CustomOperationDelegate> delegate;
@end
#import "CustomOperation.h"
@implementation CustomOperation
-(void)main
{
NSString *finishMsg = @"";
if ([self.delegate respondsToSelector:@selector(customOperation:didFished:)]) {
dispatch_async(dispatch_get_main_queue(), ^{
[self.delegate downLoadOperation:self didFished: finishMsg];
});
}
}
@end
8.5 操作依赖性
- NSOperation之间可以设置依赖来保证执行顺序,⽐如一定要让操作A执行完后,才能执行操作B,可以像下面这么写
[operationB addDependency:operationA]; // 操作B依赖于操作
NSInvocationOperation *operation1=[[NSInvocationOperation alloc]initWithTarget:self selector:@selector(test1) object:nil];
NSInvocationOperation *operation2=[[NSInvocationOperation alloc]initWithTarget:self selector:@selector(test2) object:nil];
NSBlockOperation *operation3=[NSBlockOperation blockOperationWithBlock:^{
for (int i=0; i<5; i++) {
NSLog(@"NSBlockOperation3--1----%@",[NSThread currentThread]);
}
}];
[operation3 addExecutionBlock:^{
for (int i=0; i<5; i++) {
NSLog(@"NSBlockOperation3--2----%@",[NSThread currentThread]);
}
}];
[operation3 addDependency:operation1];
[operation1 addDependency:operation2];
NSOperationQueue * queue=[[NSOperationQueue alloc]init];
[queue addOperation:operation1];
[queue addOperation:operation2];
[queue addOperation:operation3];
8.6 监听任务执行完毕
NSBlockOperation *operation=[NSBlockOperation blockOperationWithBlock:^{
NSLog(@"-operation-执行任务一-%@",[NSThread currentThread]);
}];
operation.completionBlock=^{
NSLog(@"--接着执行任务二--");
};
NSOperationQueue *queue=[[NSOperationQueue alloc]init];
[queue addOperation:operation];