iOS进阶之多线程

时间:2023-03-08 17:52:20

多线程

注意:iOS关于UI的刷新和添加必须在主线程中操作!

pthread的创建方法:

    pthread_t pthread;

    //第一个参数 线程指针
//第二个参数 线程的一些属性
//第三个参数 函数指针 用于执行方法
//第四个参数 线程中的传值
pthread_create(&pthread, NULL, run, NULL);

当应用程序刚运行的时候, 系统会自动为我们开放一个线程,该线程为主线程.

子线程是程序员用代码手动开启的线程,它存在的意义是为了执行耗时操作的任务.

一、NSThread的创建方法:

1.

    NSThread *thread = [[NSThread alloc] initWithTarget:self selector:@selector(haoshicaozuo) object:@""];
thread.name = @"";
//开启线程
[thread start];

2.快捷创建

[NSThread detachNewThreadSelector:@selector(haoshicaozuo) toTarget:self withObject:@""];
[self performSelectorInBackground:@selector(haoshicaozuo) withObject:@""];

下面一行代码指的是睡眠时间, 根据特定需求修改时长.

[NSThread sleepForTimeInterval:0.5];

二、NSOperation

NSOperation是一个抽象类,我们一般不直接使用它,而是使用它的子类NSInvocationOperation和NSBlockOperation,如果他们单独使用都是在主线程执行,只有和队列放在一起使用时在子线程执行.

NSInvocationOperation *operation1 = [[NSInvocationOperation alloc] initWithTarget:self selector:@selector(operationAction1) object:nil];
// [operation1 start];
NSInvocationOperation *operation2 = [[NSInvocationOperation alloc] initWithTarget:self selector:@selector(operationAction2) object:nil];
NSBlockOperation *operation3 = [NSBlockOperation blockOperationWithBlock:^{
for (int i = ; i < ; i++) {
NSLog(@"%d", i);
}
}];
//加入到队列
//mainQueue代表着主队列
// NSOperationQueue *queue = [NSOperationQueue mainQueue]; //如果是alloc init 那就代表着其他对列
//先加的先执行,后加的后执行, 但是执行的时间不一定, 可能后执行的比先执行的先执行完
NSOperationQueue *queue = [[NSOperationQueue alloc] init];
[queue addOperation:operation1];
[queue addOperation:operation2];
[queue addOperation:operation3];

三、GCD

异步: 不在一个线程执行

同步: 在同一个线程执行

串行: 串在一起执行

并行: 一起执行

同步 + 主队列   :所有通过GCD提交到主队列的任务必须是异步的, 否则会造成死锁

异步 + 主队列 : 不开辟线程, 就在主线程执行 (主队列就是串行的)

同步 + 串行对列: 不具备开启线程的能力, 在当前线程完成任务

异步 + 串行      :具备开启线程的能力, 但是任务是串行的,执行完一个才会去执行下一个

同步 + 并行队列 : 不具备开启线程的能力,并发的功能也就没用了

  并行队列的两种创建方式:

dispatch_queue_t queue = dispatch_queue_create("sb.2b.com", DISPATCH_QUEUE_CONCURRENT);
dispatch_queue_t queue = dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, );

异步 + 并发队列

三(一):GCD网络请求:

- (void)viewDidLoad {
[super viewDidLoad];
// Do any additional setup after loading the view, typically from a nib. dispatch_queue_t queue = dispatch_queue_create("aaa", DISPATCH_QUEUE_CONCURRENT);
dispatch_async(queue, ^{
NSURL *url = [NSURL URLWithString:@"https://ss0.bdstatic.com/94oJfD_bAAcT8t7mm9GUKT-xh_/timg?image&quality=100&size=b4000_4000&sec=1464140268&di=6b6b2e3ea5da34b7da1e02fd28c7acd2&src=http://pic36.nipic.com/20131115/12106414_153522431000_2.jpg"];
NSData *data = [NSData dataWithContentsOfURL:url];
dispatch_sync(dispatch_get_main_queue(), ^{
self.myImageView.image = [UIImage imageWithData:data];
});
}); }

三(二):GCD函数的使用:

延迟执行block

void dispatch_after(dispatch_time_t when, dispatch_queue_t queue, dispatch_block_t block);

重复执行block,需要注意的是这个方法是同步返回,也就是说等到所有block执行完毕才返回,如需异步返回则嵌套在dispatch_async中来使用。多个block的运行是否并发或串行执行也依赖queue的是否并发或串行。

void dispatch_apply(size_t iterations, dispatch_queue_t queue, void (^block)(size_t));