GCD的基本使用

//
//  ViewController.m
//  gcd队列与函数
//
//  Created by 诠释 on 15/9/3.
//  Copyright (c) 2015年 诠释. All rights reserved.
//

#import "ViewController.h"

@interface ViewController ()

@property (nonatomic, weak) UIImageView* imageView;

@end

@implementation ViewController

- (void)viewDidLoad
{
    [super viewDidLoad];

    //获得主队列
    dispatch_queue_t mainQueue = dispatch_get_main_queue();

    //创建一个串行队列
    // 参数1: 队列标记,类似于名字(一般是公司域名反写,可以传nil).
    // 参数2: 标记队列类型,是什么类型就传什么值.
    dispatch_queue_t serialQueue = dispatch_queue_create(nil, DISPATCH_QUEUE_SERIAL);
    //创建一个并发队列
    dispatch_queue_t concurrentQueue = dispatch_queue_create(0, DISPATCH_QUEUE_CONCURRENT);

    //获得全局并发队列
    //参数1:队列优先级,一般直接写0,或者写DISPATCH_QUEUE_PRIORITY_DEFAULT(默认)
    dispatch_queue_t globalQueue = dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0);

//     队列/主队列 + 同步/异步 的使用
    //串行队列+同步  没有开启新线程,串行执行任务
    dispatch_sync(serialQueue, ^{

        NSLog(@"我是在串行队列中使用同步执行的函数(任务)");
    });

    //并发队列 + 同步 没有开启新线程,串行执行任务

    dispatch_sync(concurrentQueue, ^{

        NSLog(@"我是在并发队列中使用同步执行的函数(任务)");
    });

    //并发队列 + 异步 开启新线程,并发执行任务
    dispatch_async(serialQueue, ^{

        NSLog(@"我是在并发队列中使用异步执行的函数(任务)");
    });

    //串行队列 + 异步 开启新线程,串行执行任务
    dispatch_async(serialQueue, ^{

        NSLog(@"我是在串行队列中使用异步执行的函数(任务)");
    });

    //主队列 + 同步 不开启新线程,串行执行任务  会卡死当前串行队列
    dispatch_sync(mainQueue, ^{

        NSLog(@"我是在主队列中使用同步执行的函数(任务),我会导致主队列堵死,因为主队列执行到我这里,我在等待主队列执行完当前任务(也就是我),然后在执行我本身的任务,可是我需要主队列执行完毕后才能执行我的任务,大家一起完蛋,死循环");
    });

    //主队列 + 异步 不开启新线程,串行执行任务
    dispatch_async(mainQueue, ^{

        NSLog(@"我是在主队列中使用异步执行的函数(任务),因为我在主队列,所以我不会开启新的线程,但是我不会堵死主线程,我会等主线程执行完毕当前任务执行完(不包括我),然后在执行我本身的任务");
    });

//    线程通信 当前环境,在并发队列中使用异步执行下载图片(耗时操作)
    dispatch_async(concurrentQueue, ^{

        NSURL* url = [NSURL URLWithString:@"图片资源路径"];

        NSData* data = [NSData dataWithContentsOfURL:url];

        UIImage* image = [UIImage imageWithData:data];

        //方式1 主线程相对于子线程也是异步
        dispatch_async(dispatch_get_main_queue(), ^{

            NSLog(@"我是在子线程中返回到主线程执行的任务1");

            self.imageView.image = image;
        });

        //waitUntilDone:当前线程是否等待该任务执行完毕
        //方式2 在主线程中执行settingImage方法,
        [self performSelectorOnMainThread:@selector(settingImage:) withObject:image waitUntilDone:NO];

        //方式3  在方式2上充分使用了使用系统方法的一种优化
        //        self.imageView在主线程中调用setImage:方法 == 在主线程[self.imageView setImage:image];
        [self.imageView performSelectorOnMainThread:@selector(setImage:) withObject:image waitUntilDone:NO];

        //方式4
        [self.imageView performSelector:@selector(setImage:) onThread:[NSThread mainThread] withObject:image waitUntilDone:NO];
    });

//    延时调用
    //方式1:
    dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(10 * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{
        //延时调用内容
    });

    //方式2: 延时操作执行线程取决于self在哪个线程
    [self performSelector:@selector(selector) withObject:nil afterDelay:10];

//    组队列
    //创建组队列
    dispatch_group_t group = dispatch_group_create();

    dispatch_group_async(group, serialQueue, ^{
        //耗时操作1
    });

    dispatch_group_async(group, serialQueue, ^{
        //耗时操作2
    });

    //当组队列任务执行完毕后会调用该方法,然后该方法根据参数去哪个队列执行后续操作
    dispatch_group_notify(group, dispatch_get_main_queue(), ^{

    });
}

//方式2调用的方法  在主线程中设置图片
- (void)settingImage:(UIImage*)image
{
    self.imageView.image = image;
}

@end
时间: 2024-10-14 04:01:38

GCD的基本使用的相关文章

dutacm.club 1094: 等差区间(RMQ区间最大、最小值,区间GCD)

1094: 等差区间 Time Limit:5000/3000 MS (Java/Others)   Memory Limit:163840/131072 KB (Java/Others)Total Submissions:655   Accepted:54 [Submit][Status][Discuss] Description 已知一个长度为 n 的数组 a[1],a[2],-,a[n],我们进行 q 次询问,每次询问区间 a[l],a[l+1],-,a[r?1],a[r] ,数字从小到大

iOS GCD中级篇 - dispatch_group的理解及使用

前文我们讲了GCD基础篇,以及同步.异步,并发.并行几个概率的理解. 参考链接: iOS GCD基础篇 - 同步.异步,并发.并行的理解 现在讲一下dispatch_group的概念以及几种场景下的使用 1.关于dispatch_group 把一组任务提交到队列中,这些队列可以不相关,然后监听这组任务完成的事件. 最常见的几个方法: 1.dispatch_group_create创建一个调度任务组 2.dispatch_group_async 把一个任务异步提交到任务组里 3.dispatch_

转 GCD

GCD 深入理解:第一部分 本文翻译自 http://www.raywenderlich.com/60749/grand-central-dispatch-in-depth-part-1 原作者:Derek Selander 译者:@nixzhu 虽然 GCD 已经出现过一段时间了,但不是每个人都明了其主要内容.这是可以理解的:并发一直很棘手,而 GCD 是基于 C 的 API ,它们就像一组尖锐的棱角戳进 Objective-C 的平滑世界.我们将分两个部分的教程来深入学习 GCD . 在这两

GCD多线程死锁总结

// //  ViewController.m //  多线程 // // #import "ViewController.h" @interface ViewController () @end @implementation ViewController /* >1 队列和线程的区别: 队列:是管理线程的,相当于线程池,能管理线程什么时候执行. 队列分为串行队列和并行队列 串行队列:队列中的线程按顺序执行(不会同时执行) 并行队列:队列中的线程会并发执行,可能会有一个疑问,队

GCD 常用操作

GCD多线程操作 1)用得最多的操作 //获取全局队列 dispatch_queue_t queue = dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0); //异步执行 dispatch_async(queue, ^{ //下载图片 dispatch_async(dispatch_get_main_queue(), ^{ //回到主线程更新UI }); }); ? 2)延时执行 1-调用NSObject方法 [Self

GCD

Grand Central Dispatch (GCD)是Apple开发的一个多核编程的解决方法. dispatch queue分成以下三种: 1)运行在主线程的Main queue,通过dispatch_get_main_queue获取. /*! * @function dispatch_get_main_queue * * @abstract * Returns the default queue that is bound to the main thread. * * @discussi

iOS开发——多线程OC篇&GCD实用总结

GCD实用总结 图片下载 注:iOS开发中常见GCD的实用也就这些了, 先来看看之前我们经常使用的方式: 1 static NSOperationQueue * queue; 2 3 - (IBAction)someClick:(id)sender { 4 self.indicator.hidden = NO; 5 [self.indicator startAnimating]; 6 queue = [[NSOperationQueue alloc] init]; 7 NSInvocationO

猫猫学iOS(五十二)多线程网络之GCD下单例设计模式

猫猫分享,必须精品 原创文章,欢迎转载.转载请注明:翟乃玉的博客 地址:http://blog.csdn.net/u013357243?viewmode=contents 单例模式 1:单例模式的作用 可以保证在程序运行过程,一个类只有一个实例,而且该实例易于供外界访问 从而方便地控制了实例个数,并节约系统资源 单例模式的使用场合 在整个应用程序中,共享一份资源(这份资源只需要创建初始化1次) 简单来说,就是我弄了一个工具类,他就有一份,比如我设计了一个音乐播放器NYPlayer,这个播放器类我

iOS 开发之多线程之GCD

1.GCD(Grand Centrol Dispath) 并行:宏观以及微观都是两个人再拿着两把铁锹在挖坑,一小时挖两个大坑 并发:宏观上是感觉他们都在挖坑,微观是他们是在使用一把铁锹挖坑,一小时后他们挖了两个小坑. 总结:就单个cpu来说,大部分进程是并发进行的,就是一把铁锹,你一下我一下,只是间隔时间较短,用户感觉不到而已. 应用: GCD包括: (1)实际使用中 //dispatch_get_global_queue(0, 0)第一个0是优先级,第二个保留字段 dispatch_async

hdu 4497 GCD and LCM

GCD and LCM Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65535/65535 K (Java/Others)Total Submission(s): 1092    Accepted Submission(s): 512 Problem Description Given two positive integers G and L, could you tell me how many solutions of (