首先,先介绍几个概念:GCD,队列,串行,并行,同步,异步。
GCD(Grand Central Dispatch):
GCD的基本思想就是就将操作s放在队列s中去执行
队列(FIFO):
队列是一种先进先出的组织方式,我看到最搞笑也很形象的解释是:(队列和栈的区别:吃多了拉是队列,吃多了吐是栈)。
串行和并行的概念若还是不清楚的,我再举个例子:有10个人在超市买完东西同时到一个收银点排队依次结帐走人,前一个结帐操作不完成,后一个就得等着。这就是典型的串行。10个人去不同的10个收银点同时结帐,谁先结完帐谁就先走。这就是并行。还是不明白的话请看下面例子。
同步和异步(更具体的请看百科)
请看下面四幅图片:
请注意:在并行队列中,异步任务的位置是没有意义的,即不管不放在什么位置,都会并发的去执行!
测试源码链接:http://pan.baidu.com/s/1bnCd8HT