免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
1234下一页
最近访问板块 发新帖
查看: 10667 | 回复: 39
打印 上一主题 下一主题

怎样编程降低cpu的利用率 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2006-08-11 15:13 |只看该作者 |倒序浏览
怎样编程可以使每一个线程获得少点 CPU

主线程create 太多线程进程读文件,CPU会升很高,怎样才能让 CPU不升这么高。?

论坛徽章:
0
2 [报告]
发表于 2006-08-11 15:17 |只看该作者
nice( 15 )

论坛徽章:
0
3 [报告]
发表于 2006-08-11 15:25 |只看该作者
我试过了。。好像不行。。。因为线程都在不停的 I/O..

论坛徽章:
0
4 [报告]
发表于 2006-08-11 15:27 |只看该作者
封装IO,同时只允许一个IO进行。
不过这样分线程,又好像没意义了,呵呵。
毕竟你有那么多IO要去做,似乎很难降低啊。

论坛徽章:
0
5 [报告]
发表于 2006-08-11 15:30 |只看该作者
或者同时只允许两个IO进行。其他的都给我等着?

论坛徽章:
0
6 [报告]
发表于 2006-08-11 15:40 |只看该作者
可我要提高并发度啊。。

论坛徽章:
0
7 [报告]
发表于 2006-08-11 15:44 |只看该作者
原帖由 HeavenTear 于 2006-8-11 15:25 发表
我试过了。。好像不行。。。因为线程都在不停的 I/O..

那是因为你系统空闲,除了你的程序,没有其他的在运行;
nice是改变进程优先级,当你的系统有其他优先级高的进程后,优先级低的进程cpu占用率自然就下来了,系统不会让优先级高的进程占着茅坑不拉屎,不会让进程因为优先级低就的不到时间片,这个调度是自动调整的

论坛徽章:
0
8 [报告]
发表于 2006-08-11 16:06 |只看该作者
// compute and set reduced prioity
         short ts_maxupri = ((tsinfo_t*)(&pc_info.pc_clinfo[0]))->ts_maxupri;
         ts_parms_ptr->ts_uprilim = 0 - (ts_maxupri / 2); // reduce priority to 25% (range is +ts_maxupri thru -ts_maxupri)
         ts_parms_ptr->ts_upri = ts_parms_ptr->ts_uprilim;
         status = priocntl(P_LWPID, P_MYID, PC_SETPARMS, reinterpret_cast<char*>(&pc_parms));



请问上面代码是什么意思?
通过注释,使reduce priority to 25% , 但我怎么感觉是一半啊。。。

论坛徽章:
0
9 [报告]
发表于 2006-08-11 17:48 |只看该作者
顶先。。

论坛徽章:
0
10 [报告]
发表于 2006-08-11 18:27 |只看该作者
为什么要降低cpu呢,如果不是程序设计有问题的话,我认为没有必要刻意去降低
程序的cpu占用。它的占用高是因为有那么多cpu让它占,如果有好多竞争者的话
它的cpu占用自然就会降下来了
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP