免费注册 查看新帖 |

Chinaunix

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

线程的条件变量问题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2008-10-30 17:24 |只看该作者 |倒序浏览
void *decrement_count(void *arg)
{
        pthread_mutex_lock(&count_lock);
        while (count == 0)
                pthread_cond_wait(&count_nonzero, &count_lock);
        count = count - 1;
        printf("LINE:%d %d\n", __LINE__, count);
        pthread_mutex_unlock(&count_lock);
        pthread_exit(NULL);
}

void *increment_count(void *arg)
{
        pthread_mutex_lock(&count_lock);
        if (count == 0)
                pthread_cond_signal(&count_nonzero);
        count = count + 1;

        printf("LINE:%d %d\n", __LINE__, count);
        sleep(2);
        pthread_mutex_unlock(&count_lock);
        pthread_exit(NULL);
}


不理解这句
        while (count == 0)
                pthread_cond_wait(&count_nonzero, &count_lock);

为什么非要用while呢?在前面已经由pthread_mutex_lock(&count_lock);上了锁,所以在while (count == 0)和pthread_cond_wait(&count_nonzero, &count_lock);之间,是不会有别的进程产生count的变化了。所以不明白这个while存在的意义了,请大侠指教

[ 本帖最后由 zhlyp 于 2008-10-30 17:27 编辑 ]

论坛徽章:
11
技术图书徽章
日期:2014-03-01 14:44:34天蝎座
日期:2014-05-21 22:11:59金牛座
日期:2014-05-30 17:06:14
2 [报告]
发表于 2008-10-30 21:32 |只看该作者
有多种情况可以使pthread_cond_wait返回,线程signal或broadcast只是其中之一,wait返回后有可能count == 0,所以需要循环直到条件真正满足

另外互斥锁保护的代码尽量要少,否则线程的并发也没什么意义了,比如你代码中printf sleep这类东西就没必要放到互斥锁内。

论坛徽章:
0
3 [报告]
发表于 2008-10-31 09:13 |只看该作者
了解了
原来pthread_cond_wait会解锁

论坛徽章:
224
2022北京冬奥会纪念版徽章
日期:2015-08-10 16:30:32操作系统版块每日发帖之星
日期:2016-02-18 06:20:00操作系统版块每日发帖之星
日期:2016-03-01 06:20:00操作系统版块每日发帖之星
日期:2016-03-02 06:20:0015-16赛季CBA联赛之上海
日期:2019-09-20 12:29:3219周年集字徽章-周
日期:2019-10-01 20:47:4815-16赛季CBA联赛之八一
日期:2020-10-23 18:30:5320周年集字徽章-20	
日期:2020-10-28 14:14:2615-16赛季CBA联赛之广夏
日期:2023-02-25 16:26:26CU十四周年纪念徽章
日期:2023-04-13 12:23:1015-16赛季CBA联赛之四川
日期:2023-07-25 16:53:45操作系统版块每日发帖之星
日期:2016-05-10 19:22:58
4 [报告]
发表于 2009-04-25 15:11 |只看该作者
up

论坛徽章:
0
5 [报告]
发表于 2009-04-25 20:27 |只看该作者
if (count == 0)
                pthread_cond_signal(&count_nonzero);
        count = count + 1;
=============================
这里之间如果发生线程切换。。。。。。那么就要while了
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP