多线程GCD

同步:不会开辟新线程     dispatch_sync


 异步:开辟新线程            dispatch_async


 串行:必须等待前一个任务完成才会继续执行下一个任务 

 dispatch_queue_t  queue=dispatch_queue_create("test",NULL);


 并行:可以多个任务同时执行   

 dispatch_queue_t queue=dispatch_get_global_queue(0, 0);


一、同步串行

1、创建一个串行队列 是C语言不能写成nil

    dispatch_queue_t queue=dispatch_queue_create("test",NULL);

同步任务

dispatch_sync(queue, ^{

        //    执行的任务体

        NSLog(@"当前线程%@",[NSThread currentThread]);

        for(int i=0;i<50;i++)

        {

            NSLog(@"i===%d",i);

        }

    });

dispatch_sync(queue, ^{

        //    执行的任务体

        NSLog(@"当前线程1%@",[NSThread currentThread]);

        for(int i=0;i<50;i++)

        {

            NSLog(@"j===%d",i);

        }

    });

输出:

2016-04-29 15:10:53.430 多线程--GCD[3594:204068] 主线程<NSThread: 0x7f9b1af04fc0>{number = 1, name = main}

2016-04-29 15:10:53.431 多线程--GCD[3594:204068] 当前线程<NSThread: 0x7f9b1af04fc0>{number = 1, name = main}

结果:i先输出完之后,j在进行输出 都是主线程
同步不会开辟新线程 还是在主线程执行 和调用方法一样
二、异步串行

//    异步串行(创建新线程 执行按顺序)

    NSLog(@"主线程%@",[NSThread currentThread]);

     //创建一个串行的队列  这是C

    dispatch_queue_t queue=dispatch_queue_create("test",NULL);

    //异步任务

    dispatch_async(queue, ^{

        NSLog(@"当前线程%@",[NSThread currentThread]);

        for(int i=0;i<50;i++)

        {

            NSLog(@"i===%d",i);

        }

    });

    dispatch_async(queue, ^{

        //    执行的任务体

        NSLog(@"当前线程1%@",[NSThread currentThread]);

        for(int i=0;i<50;i++)

        {

            NSLog(@"j===%d",i);

        }

    });

结果:

2016-04-29 15:12:01.869 多线程--GCD[3612:205160] 主线程<NSThread: 0x7f83b3c01410>{number = 1, name = main}

2016-04-29 15:12:01.870 多线程--GCD[3612:205195] 当前线程<NSThread: 0x7f83b3d0ab50>{number = 2, name = (null)}

结果:i先输出完之后,j在进行输出 创建了一个子线程

创建新线程 执行按顺序 

三、同步并行

//  同步并行

    NSLog(@"主线程%@",[NSThread currentThread]);

    //创建一个并行的队列  这是C

    dispatch_queue_t queue=dispatch_get_global_queue(00);


    dispatch_sync(queue, ^{

        //    执行的任务体

        NSLog(@"当前线程%@",[NSThread currentThread]);

        for(int i=0;i<50;i++)

        {

            NSLog(@"i===%d",i);

        }

    });

    dispatch_sync(queue, ^{

        //    执行的任务体

        NSLog(@"当前线程1%@",[NSThread currentThread]);

        for(int i=0;i<50;i++)

        {

            NSLog(@"j===%d",i);

        }

    });

结果:

2016-04-29 15:22:38.408 多线程--GCD[3653:211984] 主线程<NSThread: 0x7fbef94025b0>{number = 1, name = main}

2016-04-29 15:22:38.409 多线程--GCD[3653:211984] 当前线程<NSThread: 0x7fbef94025b0>{number = 1, name = main}

i 全部输出之后  在输出j

(不会开辟新线程 并且 并行失效)

四、异步并行

    NSLog(@"主线程%@",[NSThread currentThread]);

//    创建并行

    dispatch_queue_t queue=dispatch_get_global_queue(00);

    dispatch_async(queue, ^{

        NSLog(@"当前线程%@",[NSThread currentThread]);

        for(int i=0;i<50;i++)

        {

            NSLog(@"i===%d",i);

        }

    });

    dispatch_async(queue, ^{

        //    执行的任务体

        NSLog(@"当前线程1%@",[NSThread currentThread]);

        for(int i=0;i<50;i++)

        {

            NSLog(@"j===%d",i);

        }

    });

结果:
2016-04-29 15:24:16.618  多线程 --GCD[3672:213363]  主线程 <NSThread: 0x7f8bb2c04ba0>{number = 1, name = main}

2016-04-29 15:24:16.619 多线程--GCD[3672:213395] 当前线程<NSThread: 0x7f8bb2e0e9f0>{number = 2, name = (null)}

2016-04-29 15:24:16.619 多线程--GCD[3672:213393] 当前线程1<NSThread: 0x7f8bb2c42460>{number = 3, name = (null)}

i,j交题输出
(创建新的线程同时进行操作)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值