之前在做项目的时候,写了一个关于多线程的,调试的时候发现运行时CPU占用率100,当时考虑的是线程重复的做某一件事情,所以主程序main不能退出,用了while(1),循环,那么问题就出在了这个while循环了。类似问题可以用下面的一个简单程序说明:
该程序创建一个线程每隔10s打印一次当前的时间
#include<pthread.h>
#include<stdio.h>
#include<time.h>
int test()
{
time_t tt;
while(1)
{
tt = time(0);
char *s =ctime(&tt);
printf("TIME:%s",s);
sleep(10);
}//end while
return 0;
}//end test
int main()
{
int ret;
pthread_t id;
pthread_attr_t attr;
char c;
ret = pthread_attr_init(&attr);
if(ret == -1)
{
perror("pthread_attr_init Error:");
return -1;
}
ret = pthread_attr_setdetachstate(&attr,PTHREAD_CREATE_DETACHED);
if(ret == -1)
{
perror("detach Error:");
return -1;
}
ret = pthread_create(&id,&attr,(void *)&test,NULL);
if(ret == -1)
{
perror("pthread_create Error:");
return -1;
}
//c = getchar();
while (1)
{
sleep(3);
}//end while
return 0;
}
之前出问题的程序在main函数的while(1)里没有sleep(3)操作,这样就导致了主程序main无限制的占用了cpu,当加了sleep之后发现CPU降下来了。希望对大家有用。