2.GCD一

2019-02-03  本文已影响16人  你weixiao的时候很美
1.简介

1.定义:Grand Central Dispatch 是异步执行任务的技术之一。

将线程管理的代码在系统级实现。我们只需要定义任务并追加到适当的DIspath Queue中,GCD就能生成必要的线程并按计划执行任务。

2.相比于NSThread的优势:

2.Dispatch Queue

1.Dispatch Queue 是执行处理的等待队列。

2.Dispatch Queue是队列,按照追加的顺序(先进先出FIFO)执行处理。

3.在执行处理时,存在2中Dispatch Queue。

3.队列的生成和获取

1.通过GCD来生成Dispatch Queue

//创建串行队列
dispatch_queue_t serialQueue = dispatch_queue_create("com.weixiao.mySerialQueue",NULL);

//创建并发队列
dispatch_queue_t concurrentQueue = dispatch_queue_create("com.weixiao.myConcreteQueue", DISPATCH_QUEUE_CONCURRENT);

2.获取系统提供的Dispatch Queue

// Main Queue
dispatch_queue_t mainDispatchQueue = dispatch_get_main_queue();

//Global Queue 
dispatch_queue_t defaultGlobalDispatchQueue = dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0);
4.dispatch_async和dispatch_sync

1.将任务添加到队列有两种函数:

// 同步函数
dispatch_sync(queue,^{NSLog(@"black");});

//异步函数
dispatch_async(queue,^{NSLog(@"black");});

2.当同步和异步函数,串行和并发队列组合,串行队列情况:

// 1 serial, sync   打印1234
serialQueue.sync {
  print(1)
}
print(2)
serialQueue.sync {
  print(3)
}
print(4)

//2 serial, async  打印24  打印13    24 和13之间情况不定
serialQueue.async {
  print(1)
}
print(2)
serialQueue.async {
  print(3)
}
print(4)

//3 serial, sync in async  打印1 打印2   死锁。
print(1)
serialQueue.async {
  print(2)
  serialQueue.sync {
    print(3)
  }
  print(4)
}
print(5)

//4  serial, async in sync // 打印1  打印24  打印5    3在2后,位置不定。
print(1)
serialQueue.sync {
  print(2)
  serialQueue.async {
    print(3)
  }
  print(4)
}
print(5)

并发队列情况如下:

//1 concurrent, sync     打印1234
concurrentQueue.sync {
  print(1)
}
print(2)
concurrentQueue.sync {
  print(3)
}
print(4)

//2 concurrent, async   打印24    1和3 情况不定。
concurrentQueue.async {
  print(1)
}
print(2)
concurrentQueue.async {
  print(3)
}
print(4)

//3 concurrent, sync in async  打印15   打印234    234在1后,情况不定。
print(1)
concurrentQueue.async {
  print(2)
  concurrentQueue.sync {
    print(3)
  }
  print(4)
}
print(5)


//4 concurrent, async in sync   打印1  打印24  打印5  3在2后情况不定。
print(1)
concurrentQueue.sync {
  print(2)
  concurrentQueue.async {
    print(3)
  }
  print(4)
}
print(5)

上一篇下一篇

猜你喜欢

热点阅读