免费注册 查看新帖 |

Chinaunix

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

这个linux多线程程序的执行结果运行怎么总是同一个? [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2007-05-06 16:10 |只看该作者 |倒序浏览
#include <stdio.h>
#include <pthread.h>
void thread(void)
{
int i;
for(i=0;i<3;i++)
printf("This is a pthread.\n");
}
                                                                                
int main(void)
{
pthread_t id;
int i,ret;
ret=pthread_create(&id,NULL,(void *) thread,NULL);
if(ret!=0){
printf ("Create pthread error!\n");
exit (1);
}
for(i=0;i<3;i++)
printf("This is the main process.\n");
pthread_join(id,NULL);
return (0);
}

结果总是这样:[mly@localhost c_language_temp]$ gcc -lpthread -o thread thread.c
[mly@localhost c_language_temp]$ ./thread
This is a pthread.
This is a pthread.
This is a pthread.
This is the main process.
This is the main process.
This is the main process.
书上说结果回有不同的.可为什么多次运行的结果是相同的?

论坛徽章:
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
2 [报告]
发表于 2007-05-06 17:24 |只看该作者
原帖由 from2005on 于 2007-5-6 16:10 发表于 1楼  
书上说结果回有不同的.可为什么多次运行的结果是相同的?

书上说的是各次运行结果一定不同还是可能不同?

论坛徽章:
0
3 [报告]
发表于 2007-05-06 17:41 |只看该作者
原帖由 from2005on 于 2007-5-6 16:10 发表于 1楼  
#include <stdio.h>
#include <pthread.h>
void thread(void)
{
int i;
for(i=0;i<3;i++)
printf("This is a pthread.\n");
}
                                             ...



按道理说是应该不相同的,但是pthread_create()这个函数执行之后就马上去调用thread这个子线程,而main()这个线程中还要再进行一次
if()判断,而那打印3的时间太短了,一下子就完了,所以说只有一个输出,你可以把3改得更大一点,也许就不一样了!改成1000吧!

论坛徽章:
3
2015年迎新春徽章
日期:2015-03-04 09:56:11数据库技术版块每日发帖之星
日期:2016-08-03 06:20:00数据库技术版块每日发帖之星
日期:2016-08-04 06:20:00
4 [报告]
发表于 2007-05-09 00:58 |只看该作者
尽信书不如无书
3太短了,你搞个几千的,然后重定向看看。

论坛徽章:
0
5 [报告]
发表于 2007-05-09 11:23 |只看该作者
人家书上的环境是比较慢的机子,
计算机越快,越是相同。
因为线程都是瞬间执行完成了。

论坛徽章:
0
6 [报告]
发表于 2007-05-09 11:30 |只看该作者
This is the main process.
This is the main process.
This is the main process.
This is a pthread.
This is a pthread.
This is a pthread.
我的机子每次都是这样,呵呵。

论坛徽章:
0
7 [报告]
发表于 2007-05-09 12:47 |只看该作者
原帖由 prettywolf 于 2007-5-9 11:30 发表于 6楼  
This is the main process.
This is the main process.
This is the main process.
This is a pthread.
This is a pthread.
This is a pthread.
我的机子每次都是这样,呵呵。


我的机器的结果和你的差不多,不过有时候pthread在前面
我后来换成了100000, 结果就不同了.
呵呵.
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP