信号量是一个整数,在创建的时候会有一个初始值,这个初始值往往代表我要控制的同时操作的并发数。在操作中,对信号量会有两种操作:信号通知与等待。信号通知时,信号量会+1,等待时,如果信号量大于0,则会将信号量-1,否则,会等待直到信号量大于0。什么时候会大于零呢?往往是在之前某个操作结束后,我们发出信号通知,让信号量+1。
说完概念,我们来看看GCD中的三个信号量操作:
- dispatch_semaphore_create:创建一个信号量(semaphore)
- dispatch_semaphore_signal:信号通知,即让信号量+1
- dispatch_semaphore_wait:等待,直到信号量大于0时,即可操作,同时将信号量-1
在使用的时候,往往会创建一个信号量,然后进行多个操作,每次操作都等待信号量大于0再操作,同时信号昂-1,操作完后将信号量+1,类似下面这个过程:
- (void)semaphore
{
// 1.创建一个信号量 ,且设置同时操作的并发数为5
dispatch_semaphore_t semaphore = dispatch_semaphore_create(5);
// 2.创建100个任务
for (int i = 0; i < 100; i++) {
// 3.当信号量大于0时即可往下执行, 同时将信号量-1
dispatch_semaphore_wait(semaphore, DISPATCH_TIME_FOREVER);
// 4.异步执行任务
dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT,0), ^{
[NSThread sleepUntilDate:[NSDate dateWithTimeIntervalSinceNow:1.0]];
// 5.信号通知,即让信号量+1
dispatch_semaphore_signal(semaphore);
NSLog(@"当前是:%d任务并且在%@线程上",i,[NSThread currentThread]);
});
}
}
上面代码表示我要操作100次,但是控制允许同时并发的操作最多只有5次,当并发量达到5后,信号量就减小到0了,这时候wait操作会起作用,DISPATCH_TIME_FOREVER表示会永远等待,一直等到信号量大于0,也就是有操作完成了,将信号量+1了,这时候才可以结束等待,进行操作,并且将信号量-1,这样新的任务又要等待。
文章摘自:http://blog.youkuaiyun.com/cloudox_/article/details/71107179