linux下pthread_cond_timedwait性能问题,cpu占用很高的问题

悟空大王 2014-05-14 02:10:15
做了一个事件处理线程,其中利用pthread_cond_timewrite来阻塞等待一定时常,然后不管是否超时,都要对队列进行一些处理,目前发现如果等待超时设置为50毫秒,cpu占用特别厉害,我的双核虚拟机都占用90%多cpu,后来发现是跑thread_cond_timewait这一块儿处理的问题,特意写了个简单的测试代码,空转的pthread_cond_timedwait,然后做一些简单运算,cpu也是很高,也能%90以上。。。。。不是每个循环都有50毫秒的等待么..
测试代码如下,哪位高手帮忙看看问题出在哪里,是哪个环节造成这么严重的cpu占用的

using namespace std;

pthread_mutex_t mutex;
pthread_cond_t cond;
bool stoped = false;
void *fun(void* data);

int main() {
pthread_mutex_init(&mutex,0);
pthread_cond_init(&cond, NULL);
pthread_t thread;

pthread_create(&thread, 0, fun, 0);
int cmd;
while(std::cin >> cmd)
{
switch(cmd)
{
case 1:
{
pthread_mutex_lock(&mutex);
pthread_cond_signal(&cond);
pthread_mutex_unlock(&mutex);
break;
}
case 99:
{
stoped = true;
break;
}
}
}
void *ret;
pthread_join(thread, &ret);
pthread_mutex_destroy(&mutex);
pthread_cond_destroy(&cond);
return 0;
}


void *fun(void* data)
{

pthread_mutex_lock(&mutex);
printf("%d\n", pthread_cond_signal(&cond));
pthread_mutex_unlock(&mutex);
while(!stoped)
{

struct timespec outtime;
struct timeval now;
pthread_mutex_lock(&mutex);
//超时等待50毫秒
uint ms = 50;
gettimeofday(&now, NULL);
now.tv_usec += ms * 1000;
if(now.tv_usec >= 1000000)
{
now.tv_sec += now.tv_usec / 1000000;
now.tv_usec %= 1000000;
}
outtime.tv_nsec = now.tv_usec;
outtime.tv_sec = now.tv_sec;
int ret = pthread_cond_timedwait(&cond, &mutex, &outtime);
pthread_mutex_unlock(&mutex);
if (ret == 0)
{
printf("ok\n");
}
else
{
//printf("timeout \n");
}
//每次循环不管是其他线程主动有数据还是等待超时,这里都做点什么
int n ;
for (int i=0;i<100;i++)
{
if (i % 3 == 0)
{
n++;
}
}
}
return 0;
}
...全文
1128 3 打赏 收藏 转发到动态 举报
写回复
用AI写文章
3 条回复
切换为时间正序
请发表友善的回复…
发表回复
悟空大王 2014-05-14
  • 打赏
  • 举报
回复
好像就是这个问题,刚简单测试了下,的确可以了,明天再好好测测 谢谢了,结贴
悟空大王 2014-05-14
  • 打赏
  • 举报
回复
是这样么,我测试测试,我试过等待5秒的,看上去好像很准的所以才这么写了, 多谢提醒,我试试看
luotuo44 2014-05-14
  • 打赏
  • 举报
回复 1
错在这句

outtime.tv_nsec = now.tv_usec;
两边的单位不一样,一个是纳秒,一个是微秒。楼主这样赋值会使得pthread_cond_timewait的超时时间比当前时间还小。即不会等待,马上退出。所以就出现了楼主所说的占用了90%的CPU。

64,648

社区成员

发帖
与我相关
我的任务
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++ 技术论坛(原bbs)
社区管理员
  • C++ 语言社区
  • encoderlee
  • paschen
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
  1. 请不要发布与C++技术无关的贴子
  2. 请不要发布与技术无关的招聘、广告的帖子
  3. 请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下

试试用AI创作助手写篇文章吧