GCD

作者: baidaokun | 来源:发表于2016-07-27 16:04 被阅读65次

并发(concurrency)与并行(parallesim)是两个经常被混淆的概念。《七周七并发模型》开篇就说明了这两者的区别。

并发程序含有多个逻辑上的独立执行块,它们可以独立地并行执行,也可以串行执行;而并行程序是同时执行整个任务的多个部分,并行程序可能有多个独立的执行块,也可能只有一个。

如果从处理器和任务的角度来讲,粗略的理解可以是:

  1. 并发是单个处理器执行多个任务,这些任务在重叠的时间段内交叉执行,但在任何一个时间点都只有一个任务在执行。这些任务在逻辑上是同时执行,而实际上是交叉执行的。
  2. 并行是多个处理器或多核下执行多个任务,这些任务可以同时执行,即同一时间点可以有多个不同的任务在执行。这些任务在物理上是同时执行的。

简单点说就是:并行指物理上同时执行,并发指能够让多个任务在逻辑上交织执行的程序设计。如图1所示。

当然,关于并发与并行,还有很多东西需要了解。有兴趣可以看下Rob Pike的视频“Concurrency Is Not Parallelism”(O网页链接 ),里面最经典的就是那句:Concurrency is about dealing with lots of things at once. Parallelism is about doing lots of things at once.

GCD 深入理解:第一部分
GCD 深入理解:第二部分
GCD使用经验与技巧浅谈
一起来构建Dispatch Groups
Low-Level Concurrency APIs
GCD使用详解 上篇
GCD使用详解 下篇

还在疑惑并发和并行
Concurrency vs Parallelism - What is the difference?

iOS开发之再探多线程编程:Grand Central Dispatch详解
GCD那些事

相关文章

  • 多线程之GCD

    GCD介绍 1、GCD简介 2、GCD任务和队列 3、GCD 的基本使用 4、GCD 线程间的通信 5、GCD 的...

  • 扩展GCD(求逆元,解同余方程等等)

    首先要知道gcd函数的基本性质:gcd(a,b)=gcd(b,a)=gcd(|a|,|b|)=gcd(b,a%b)...

  • iOS - GCD

    目录 GCD简介 GCD核心概念 GCD队列的使用 GCD的常见面试题 GCD简介 Grand Central D...

  • iOS-多线程:GCD

    GCD 简介 GCD 任务和队列 GCD 的使用步骤 GCD 的基本使用(6种不同组合区别) GCD 线程间的通信...

  • 浅析GCD

    GCD目录: 1. GCD简介 为什么要用GCD呢? GCD可用于多核的并行运算GCD会自动利用更多的CPU内核(...

  • 7.3 多线程-GCD

    多线程-GCD 多线程-GCD-串行并行 多线程-GCD.png GCD-线程的通讯、延时操作、定时器 GCD-线...

  • iOS 多线程--GCD

    一、GCD基本介绍 1.GCD简介 GCD是Grand Central Dispatch的缩写,GCD是苹果推出的...

  • 自用算法模板(JAVA版)

    一、数论 1)GCD GCD(求最大公约数) QGCD(快速GCD) extGCD(拓展GCD,解决ax + by...

  • GCD介绍

    一、GCD简单介绍 什么是GCD GCD优势 任务和队列 GCD有2个核心概念 GCD的使用就2个步骤 将任务添加...

  • 7.多线程基础(七)GCD加强

    1.GCD串行队列和并发队列 2.GCD延时执行 3.GCD线程组:(的作用) 4.GCD定时器: GCD的实现 ...

网友评论

    本文标题:GCD

    本文链接:https://www.haomeiwen.com/subject/ekbojttx.html