首页 > 代码库 > 消耗CPU的程序
消耗CPU的程序
昨天领导交代客户需要一个可以测试CPU性能的脚本,问题简化下就是说要做一个可以手动设置对CPU产生消耗的程序。心想哪有这种脚本,或许性能测试工具还差不多。琢磨了下,或许用死循环可以达到差不多的效果,但是单进程(单线程)造成的影响有限,因为服务器都是多个物理核心。那就是用多线程吧,手动写了个多线程demo,生成后发现线程都集中在一个CPU内工作,虽然把单个CPU搞成100%了,但是整体消耗不大(大约10%左右)。后来百度了下说得CPU绑定线程才有用,但是这方面不是一下就能熟悉的,所以还是多进程的实现较为简单。
代码很简单:
#include <stdio.h>#include <stdlib.h>#include <sys/types.h>#include <unistd.h>#include <wait.h>/***@Usage: ./$0 [SUBPROCESS NUMBER]*/int main(int argc, char *argv[]){ pid_t pid; int i, pn=4; if(argc==2){ pn=atoi(argv[1]); } for(i=0;i<pn;i++){ pid=fork(); if(pid<=0)break; } if(pid<0){ printf("fork() error\n"); return -1; }else if(pid==0){ //sub process works for(;;)i=(i%4)*1.0; }else{ //wait for the sub process‘s termination wait(NULL); } return 0;}
gcc -Wall test.c -o test.ochmod +x test.o#启动五个子进程试试效果./test.o 5
贴张图:
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。