博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
异步函数
阅读量:6510 次
发布时间:2019-06-24

本文共 2250 字,大约阅读时间需要 7 分钟。

 

#import "ViewController.h"

 

@interface ViewController ()

 

@end

 

@implementation ViewController

 

- (void)viewDidLoad {

    [super viewDidLoad];

 

    

    

}

 

- (void)touchesBegan:(NSSet *)touches withEvent:(UIEvent *)event

{

    NSLog(@"touchesBegan");

    // 异步函数 + 主队列

    // 结论:1.不会开启新线程

    //     2.任务按顺序执行

    dispatch_async(dispatch_get_main_queue(), ^{

        

         NSLog(@"耗时操作1:%@",[NSThread currentThread]);

    });

    

    dispatch_async(dispatch_get_main_queue(), ^{

        

        NSLog(@"耗时操作2:%@",[NSThread currentThread]);

    });

    

    dispatch_async(dispatch_get_main_queue(), ^{

        

        NSLog(@"耗时操作3:%@",[NSThread currentThread]);

    });

    NSLog(@"touchesEnd");

 

 

}

 

// 异步函数 + 并发队列

// 任务在子线程执行/会开启多条新线程

// 任务同时执行

// 并不是有多少任务就开启多少线程.

- (void)test2

{

    // 异步函数 + 并发队列

    // 任务在子线程执行/会开启多条新线程

    // 任务同时执行

    // 并不是有多少任务就开启多少线程.

    dispatch_async(dispatch_get_global_queue(0, 0), ^{

        NSLog(@"耗时操作1:%@",[NSThread currentThread]);

    });

    dispatch_async(dispatch_get_global_queue(0, 0), ^{

        NSLog(@"耗时操作2:%@",[NSThread currentThread]);

    });

    dispatch_async(dispatch_get_global_queue(0, 0), ^{

        NSLog(@"耗时操作3:%@",[NSThread currentThread]);

    });

    dispatch_async(dispatch_get_global_queue(0, 0), ^{

        NSLog(@"耗时操作4:%@",[NSThread currentThread]);

    });

    dispatch_async(dispatch_get_global_queue(0, 0), ^{

        NSLog(@"耗时操作5:%@",[NSThread currentThread]);

    });

    dispatch_async(dispatch_get_global_queue(0, 0), ^{

        NSLog(@"耗时操作6:%@",[NSThread currentThread]);

    });

    dispatch_async(dispatch_get_global_queue(0, 0), ^{

        NSLog(@"耗时操作7:%@",[NSThread currentThread]);

    });

    dispatch_async(dispatch_get_global_queue(0, 0), ^{

        NSLog(@"耗时操作8:%@",[NSThread currentThread]);

    });

}

 

 

// 异步函数 + 串行队列

// 结论: 1.开启一条线程,任务在新线程中执行.

//       2.任务按顺序执行,在同一条子线程执行.

//       3.一个队列对应一条线程

- (void)test1

{

    // 异步函数 + 串行队列

    // 结论: 1.开启一条线程,任务在新线程中执行.

    //       2.任务按顺序执行,在同一条子线程执行.

    //       3.一个队列对应一条线程

    dispatch_queue_t serialQueue1 = dispatch_queue_create("", DISPATCH_QUEUE_SERIAL);

    dispatch_queue_t serialQueue2 = dispatch_queue_create("", DISPATCH_QUEUE_SERIAL);

    

    dispatch_async(serialQueue1, ^{

        NSLog(@"耗时操作1:%@",[NSThread currentThread]);

    });

    

    dispatch_async(serialQueue2, ^{

        NSLog(@"耗时操作2:%@",[NSThread currentThread]);

    });

    

    dispatch_async(serialQueue2, ^{

        NSLog(@"耗时操作3:%@",[NSThread currentThread]);

    });

    

    dispatch_async(serialQueue1, ^{

        NSLog(@"耗时操作4:%@",[NSThread currentThread]);

    });

}

@end

转载于:https://www.cnblogs.com/R-X-L/p/4777563.html

你可能感兴趣的文章