博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
GCD之信号量机制一
阅读量:5945 次
发布时间:2019-06-19

本文共 1637 字,大约阅读时间需要 5 分钟。

在使用NSOperationQueue进行多线程编程时,可通过[queue setMaxConcurrentOperationCount:5]来设置线程池中最多并行的线程数,在GCD中信号量机制也和它相似,可以控制并发的线程数量。

1.首先熟悉下几个函数

dispatch_semaphore_create 创建一个信号量,设置一个初始值

dispatch_semaphore_signal 发送一个信号,信号通知,信号量+1
dispatch_semaphore_wait 等待信号,信号量-1

当一个信号量被通知 ,信号量就会加1,当一个信号等待,信号总量就减1,当减到信号量小于0时,线程会被阻塞,信号量不会在减了。直到信号量大于0时,线程会再次启动执行

下面参考http://blog.sina.cn/dpool/blog/s/blog_ac94a55f0101pa4l.html建了一个初始值为10的信号量

dispatch_group_t group=dispatch_group_create();   dispatch_semaphore_t semaphore=dispatch_semaphore_create(10);   dispatch_queue_t queue=dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0);   for (int i=0; i<100; i++) {       //信号量减1,如果同时开启10个以上的线程,则信号量小于等于0,此时就会阻塞该线程。       dispatch_semaphore_wait(semaphore, DISPATCH_TIME_FOREVER);       dispatch_group_async(group, queue, ^{           NSLog(@"test %d",i);       //每个线程执行减1后通过信号量通知加1,这样始终保持线程在10个之内       dispatch_semaphore_signal(semaphore);       });   }   dispatch_group_wait(group, DISPATCH_TIME_FOREVER);

 运行结果:

上面的例子可能效果不太明显,现在设置信号量初始值为1,看下 面代码段:

dispatch_group_t group=dispatch_group_create();    dispatch_semaphore_t semaphore=dispatch_semaphore_create(1);    dispatch_queue_t queue=dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0);    for (int i=0; i<100; i++) {        //信号量减1,如果同时开启10个以上的线程,则信号量小于等于0,此时就会阻塞该线程。        dispatch_semaphore_wait(semaphore, DISPATCH_TIME_FOREVER);        dispatch_group_async(group, queue, ^{            NSLog(@"test %d",i);        //每个线程执行减1后通过信号量通知加1,这样始终保持线程在10个之内        dispatch_semaphore_signal(semaphore);        });    }    dispatch_group_wait(group, DISPATCH_TIME_FOREVER);

 运行结果:

初始值设为1时,相当于是串行队列,单线程执行。

转载地址:http://ggzxx.baihongyu.com/

你可能感兴趣的文章
Linux备份ifcfg-eth0文件导致的网络故障问题
查看>>
2018年尾总结——稳中成长
查看>>
JFreeChart开发_用JFreeChart增强JSP报表的用户体验
查看>>
度量时间差
查看>>
通过jsp请求Servlet来操作HBASE
查看>>
crontab执行shell脚本日志中出现乱码
查看>>
Shell编程基础
查看>>
Shell之Sed常用用法
查看>>
3.1
查看>>
校验表单如何摆脱 if else ?
查看>>
JS敏感信息泄露:不容忽视的WEB漏洞
查看>>
分布式memcached服务器代理magent安装配置(CentOS6.6)
查看>>
Create Volume 操作(Part III) - 每天5分钟玩转 OpenStack(52)
查看>>
tomcat 8.0虚拟机配置文档
查看>>
pxc群集搭建
查看>>
JS中加载cssText延时
查看>>
常用的脚本编程知识点
查看>>
计算机网络术语总结4
查看>>
新手小白 python之路 Day3 (string 常用方法)
查看>>
soapUI的简单使用(webservice接口功能测试)
查看>>