linux pthread_cond_timedwait
场景:linux下pthread_cond_timedwait性能有关问题,cpu占用很高的有关问题
linux下pthread_cond_timedwait性能问题,cpu占用很高的问题
做了一个事件处理线程,其中利用pthread_cond_timewrite来阻塞等待一定时常,然后不管是否超时,都要对队列进行一些处理,目前发现如果等待超时设置为50毫秒,cpu占用特别厉害,我的双核虚拟机都占用90%多cpu,后来发现是跑thread_cond_timewait这一块儿处理的问题,特意写了个简单的测试代码,空转的pthread_cond_timedwait,然后做一些简单运算,cpu也是很高,也能%90以上。。。。。不是每个循环都有50毫秒的等待么..
测试代码如下,哪位高手帮忙看看问题出在哪里,是哪个环节造成这么严重的cpu占用的
------解决方案--------------------
错在这句
两边的单位不一样,一个是纳秒,一个是微秒。楼主这样赋值会使得pthread_cond_timewait的超时时间比当前时间还小。即不会等待,马上退出。所以就出现了楼主所说的占用了90%的CPU。
linux下pthread_cond_timedwait性能问题,cpu占用很高的问题
做了一个事件处理线程,其中利用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;
}
------解决方案--------------------
错在这句
outtime.tv_nsec = now.tv_usec;
两边的单位不一样,一个是纳秒,一个是微秒。楼主这样赋值会使得pthread_cond_timewait的超时时间比当前时间还小。即不会等待,马上退出。所以就出现了楼主所说的占用了90%的CPU。