免费注册 查看新帖 |

Chinaunix

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

<DONE>ubuntu下编写多线程程序,运行结果有问题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2008-11-09 18:05 |只看该作者 |倒序浏览
程序如下:
#include <pthread.h>
#include <stdio.h>

void *mm()
{
        printf("======debug\n");
}

int main()
{
        pthread_t a_thread;
        int res = pthread_create(&a_thread, NULL, mm, NULL);
        printf("res = %d\n", res);
        int i = 100000000;
        while(i--){};
        printf("======main()\n");
}

运行结果为:(ubuntu 7.04上编译运行)
res = 0
======main()

分析:
返回值res为0,说明创建新线程成功,但是却没有输出“======debug”
另外,该程序在其他机器上跑可以得到正确结果:(如下)
res = 0
======debug
======main()

猜测:
似乎是pthread库有问题,之前跑多线程程序是对的,没过几天突然就不行了,中间我好像更新了什么东西,不仅这个多线程程序运行有问题,连用g++编译简单的c++程序都会出头文件的问题
请高手解惑,谢谢!

[ 本帖最后由 yoyocall 于 2008-11-10 18:14 编辑 ]

论坛徽章:
11
技术图书徽章
日期:2014-03-01 14:44:34天蝎座
日期:2014-05-21 22:11:59金牛座
日期:2014-05-30 17:06:14
2 [报告]
发表于 2008-11-09 19:36 |只看该作者

回复 #1 yoyocall 的帖子

等待线程结束的方式很特别啊,用pthread_join好些

论坛徽章:
0
3 [报告]
发表于 2008-11-10 09:28 |只看该作者

回复 #2 timespace 的帖子

呵呵,见笑了,我想使程序尽量简单,所以只用了一个库函数

论坛徽章:
95
程序设计版块每日发帖之星
日期:2015-09-05 06:20:00程序设计版块每日发帖之星
日期:2015-09-17 06:20:00程序设计版块每日发帖之星
日期:2015-09-18 06:20:002015亚冠之阿尔艾因
日期:2015-09-18 10:35:08月度论坛发贴之星
日期:2015-09-30 22:25:002015亚冠之阿尔沙巴布
日期:2015-10-03 08:57:39程序设计版块每日发帖之星
日期:2015-10-05 06:20:00每日论坛发贴之星
日期:2015-10-05 06:20:002015年亚冠纪念徽章
日期:2015-10-06 10:06:482015亚冠之塔什干棉农
日期:2015-10-19 19:43:35程序设计版块每日发帖之星
日期:2015-10-21 06:20:00每日论坛发贴之星
日期:2015-09-14 06:20:00
4 [报告]
发表于 2008-11-10 12:22 |只看该作者
原帖由 yoyocall 于 2008-11-10 09:28 发表
呵呵,见笑了,我想使程序尽量简单,所以只用了一个库函数

多一个函数调用能复杂到什么地方去?

论坛徽章:
11
技术图书徽章
日期:2014-03-01 14:44:34天蝎座
日期:2014-05-21 22:11:59金牛座
日期:2014-05-30 17:06:14
5 [报告]
发表于 2008-11-10 13:22 |只看该作者

回复 #3 yoyocall 的帖子

不过此处用pthread_join不仅使程序更加简单,还可以避免一个问题:进程退出前,线程mm可能都没有被调度运行过,即看不到======debug。

论坛徽章:
95
程序设计版块每日发帖之星
日期:2015-09-05 06:20:00程序设计版块每日发帖之星
日期:2015-09-17 06:20:00程序设计版块每日发帖之星
日期:2015-09-18 06:20:002015亚冠之阿尔艾因
日期:2015-09-18 10:35:08月度论坛发贴之星
日期:2015-09-30 22:25:002015亚冠之阿尔沙巴布
日期:2015-10-03 08:57:39程序设计版块每日发帖之星
日期:2015-10-05 06:20:00每日论坛发贴之星
日期:2015-10-05 06:20:002015年亚冠纪念徽章
日期:2015-10-06 10:06:482015亚冠之塔什干棉农
日期:2015-10-19 19:43:35程序设计版块每日发帖之星
日期:2015-10-21 06:20:00每日论坛发贴之星
日期:2015-09-14 06:20:00
6 [报告]
发表于 2008-11-10 14:36 |只看该作者
原帖由 timespace 于 2008-11-10 13:22 发表
不过此处用pthread_join不仅使程序更加简单,还可以避免一个问题:进程退出前,线程mm可能都没有被调度运行过,即看不到======debug。

对头。在单核机器上很可能会出现这种结果,尤其是加了优化以后,他的那个 tight loop 很可能直接被删除了。在这用 sleep 可能还靠点谱。

论坛徽章:
0
7 [报告]
发表于 2008-11-10 18:11 |只看该作者

回复 #6 MMMIX 的帖子

谢谢上面各位,加了pthread_join或者将while换成sleep,程序就正确了。
不过while并没有被优化掉,我想应该是while语句让main主线程成为CPU消耗性线程,时间片分配得很长,优先级变得很高,让子线程直到主线程退出也没机会运行,所以出现上述情况
最后还有一点疑惑,留待以后思考:为什么主线程必须自己主动阻塞,子线程才有机会执行(上面的pthread_join和sleep都是主动阻塞函数)?而以前我跑同样一个没有pthread_join和sleep的程序,却能够得到正确结果,会不会是我的pthread库变掉了(被更新了,与某些库版本不兼容等),致使pthread_create产生的线程默认只具有极低的优先级,因此会这样。
最后再次感谢大家

[ 本帖最后由 yoyocall 于 2008-11-10 18:24 编辑 ]

论坛徽章:
95
程序设计版块每日发帖之星
日期:2015-09-05 06:20:00程序设计版块每日发帖之星
日期:2015-09-17 06:20:00程序设计版块每日发帖之星
日期:2015-09-18 06:20:002015亚冠之阿尔艾因
日期:2015-09-18 10:35:08月度论坛发贴之星
日期:2015-09-30 22:25:002015亚冠之阿尔沙巴布
日期:2015-10-03 08:57:39程序设计版块每日发帖之星
日期:2015-10-05 06:20:00每日论坛发贴之星
日期:2015-10-05 06:20:002015年亚冠纪念徽章
日期:2015-10-06 10:06:482015亚冠之塔什干棉农
日期:2015-10-19 19:43:35程序设计版块每日发帖之星
日期:2015-10-21 06:20:00每日论坛发贴之星
日期:2015-09-14 06:20:00
8 [报告]
发表于 2008-11-10 20:09 |只看该作者
原帖由 yoyocall 于 2008-11-10 18:11 发表
谢谢上面各位,加了pthread_join或者将while换成sleep,程序就正确了。
不过while并没有被优化掉,我想应该是while语句让main主线程成为CPU消耗性线程,时间片分配得很长,优先级变得很高,让子线程直到主线程退出也没机会运行,所以出现上述情况

最好不要猜这个,更不要根据这种猜测写代码。
最后还有一点疑惑,留待以后思考:为什么主线程必须自己主动阻塞,子线程才有机会执行(上面的pthread_join和sleep都是主动阻塞函数)?而以前我跑同样一个没有pthread_join和sleep的程序,却能够得到正确结果,

结果正确(严格来说是符合你的预期)并不代表你的代码是正确或没有问题的。

论坛徽章:
0
9 [报告]
发表于 2008-11-11 14:14 |只看该作者
多线程,任何可能结果。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP