//
// 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(, DISPATCH_QUEUE_CONCURRENT); //获得全局并发队列
//参数1:队列优先级,一般直接写0,或者写DISPATCH_QUEUE_PRIORITY_DEFAULT(默认)
dispatch_queue_t globalQueue = dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, ); // 队列/主队列 + 同步/异步 的使用
//串行队列+同步 没有开启新线程,串行执行任务
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)( * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{
//延时调用内容
}); //方式2: 延时操作执行线程取决于self在哪个线程
[self performSelector:@selector(selector) withObject:nil afterDelay:]; // 组队列
//创建组队列
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

GCD的基本使用的更多相关文章

  1. Objective-C三种定时器CADisplayLink / NSTimer / GCD的使用

    OC中的三种定时器:CADisplayLink.NSTimer.GCD 我们先来看看CADiskplayLink, 点进头文件里面看看, 用注释来说明下 @interface CADisplayLin ...

  2. iOS 多线程之GCD的使用

    在iOS开发中,遇到耗时操作,我们经常用到多线程技术.Grand Central Dispatch (GCD)是Apple开发的一个多核编程的解决方法,只需定义想要执行的任务,然后添加到适当的调度队列 ...

  3. 【swift】BlockOperation和GCD实用代码块

    //BlockOperation // // ViewController.swift import UIKit class ViewController: UIViewController { @I ...

  4. 修改版: 小伙,多线程(GCD)看我就够了,骗你没好处!

    多线程(英语:multithreading),是指从软件或者硬件上实现多个线程并发执行的技术.具有多线程能力的计算机因有硬件支持而能够在同一时间执行多于一个线程,进而提升整体处理性能.具有这种能力的系 ...

  5. GCD的相关函数使用

    GCD 是iOS多线程实现方案之一,非常常用 英文翻译过来就是伟大的中枢调度器,也有人戏称为是牛逼的中枢调度器 是苹果公司为多核的并行运算提出的解决方案 1.一次性函数 dispatch_once 顾 ...

  6. hdu1695 GCD(莫比乌斯反演)

    题意:求(1,b)区间和(1,d)区间里面gcd(x, y) = k的数的对数(1<=x<=b , 1<= y <= d). 知识点: 莫比乌斯反演/*12*/ 线性筛求莫比乌 ...

  7. hdu2588 GCD (欧拉函数)

    GCD 题意:输入N,M(2<=N<=1000000000, 1<=M<=N), 设1<=X<=N,求使gcd(X,N)>=M的X的个数.  (文末有题) 知 ...

  8. BZOJ 2820: YY的GCD [莫比乌斯反演]【学习笔记】

    2820: YY的GCD Time Limit: 10 Sec  Memory Limit: 512 MBSubmit: 1624  Solved: 853[Submit][Status][Discu ...

  9. BZOJ 2818: Gcd [欧拉函数 质数 线性筛]【学习笔记】

    2818: Gcd Time Limit: 10 Sec  Memory Limit: 256 MBSubmit: 4436  Solved: 1957[Submit][Status][Discuss ...

  10. GCD总结

    //用block只有两种:同步执行/异步执行(参数1:队列;参数二:任务) dispatch_async(dispatch_get_global_queue(0, 0),^{ });//异步在新的线程 ...

随机推荐

  1. IM通信协议逆向分析、Wireshark自定义数据包格式解析插件编程学习

    相关学习资料 http://hi.baidu.com/hucyuansheng/item/bf2bfddefd1ee70ad68ed04d http://en.wikipedia.org/wiki/I ...

  2. hihocoder #1034 毁灭者问题

    传送门 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 在 Warcraft III 之冰封王座中,毁灭者是不死族打三本后期时的一个魔法飞行单位. 毁灭者的核心技能之一, ...

  3. linux source与 . 命令

    source命令用法:source FileName作用:在当前bash环境下读取并执行FileName中的命令.注:该命令通常用命令“.”来替代.如:source .bash_rc 与 . .bas ...

  4. gcc/g++ 参数

    -static  此选项将禁止使用动态库,所以,编译出来的东西,一般都很大,也不需要什么 动态连接库,就可以运行. -share  此选项将尽量使用动态库,所以生成文件比较小,但是需要系统由动态库.

  5. MSF溢出实战教程

    1.  进入终端,开启MSF相关服务 2.  连接数据库 3.  主机扫描 发现如果有MS08_067漏洞,就可以继续渗透 4.  开始溢出 溢出成功的话 sessions -l         查看 ...

  6. Log4j使用教程 log4:WARN No appenders could be found for logger (org.springframework.web.context.ContextLoader).

    1.Logger类 通过Logger类的静态方法Logger.getRootLogger得到RootLogger.所有其他的loggers是通过静态方法Logger.getLogger来实例化并获取的 ...

  7. ngrok反向代理

    关于ngrok ngrok 是一个反向代理,通过在公共的端点和本地运行的 Web 服务器之间建立一个安全的通道.ngrok 可捕获和分析所有通道上的流量,便于后期分析和重放. 为什么使用ngrok? ...

  8. 导出Excel之Epplus使用教程2(样式设置)

    导出Excel之Epplus使用教程1(基本介绍) 导出Excel之Epplus使用教程2(样式设置) 导出Excel之Epplus使用教程3(图表设置) 导出Excel之Epplus使用教程4(其他 ...

  9. bootstrap tab切换如何让鼠标移动自动切换内容

    bootstrap集成了很多功能,比如nav-tabs组件,可以将相似的内容集中在一个区块中展示.bootstrap tab切换默认是要点击才会切换的,如何实现鼠标移动就自动切换呢?如下图所示,光标移 ...

  10. java笔记--使用线程池优化多线程编程

    使用线程池优化多线程编程 认识线程池 在Java中,所有的对象都是需要通过new操作符来创建的,如果创建大量短生命周期的对象,将会使得整个程序的性能非常的低下.这种时候就需要用到了池的技术,比如数据库 ...