免费注册 查看新帖 |

Chinaunix

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

gcc编译通过后出现的问题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2009-04-24 20:52 |只看该作者 |倒序浏览
本人编写小程序验证fork()的使用,正常的输出结果应该是:交叉输出各五行"I am parent"和"I am child",输出结果是对了,可是为什么在最后一行会出现这种情况?如下图,本人查了很多资料就是不知道怎么回事,肯请各位DX帮帮俺呀。谢谢!

未命名.jpg (11.12 KB, 下载次数: 49)

未命名.jpg

论坛徽章:
0
2 [报告]
发表于 2009-04-24 20:55 |只看该作者

回复 #1 乌龙张 的帖子

父进程先结束

论坛徽章:
0
3 [报告]
发表于 2009-04-24 21:02 |只看该作者
楼上的朋友,能不能再说明白一点呢?父进程结束,为什么子进程的最后一行结果前面要有"[root@localhost root]#”呢?为什么其它行没有呢?
本人菜鸟,谢谢!

论坛徽章:
0
4 [报告]
发表于 2009-04-24 22:14 |只看该作者

父子进程的问题

在做fork()实验的时候,实验代码如下:
main()
{
int p1,i;
while ((p1=fork())==-1);
if (p1>0)
        for (i=0;i<5;i++)
        {
                printf("I am parent.\n");
                sleep(1);
        }
else
        for (i=0;i<5;i++)
        {
                printf("I am child.\n");
                sleep(1);
        }
}
预想的结果应该是"I am parent."和"I am child"交叉显示各五次。可为什么会出来下图的结果呢?我想不明白。谢谢各位DX。

未命名.jpg (9.46 KB, 下载次数: 41)

未命名.jpg

论坛徽章:
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
5 [报告]
发表于 2009-04-24 23:08 |只看该作者
原帖由 乌龙张 于 2009-4-24 22:14 发表

预想的结果应该是"I am parent."和"I am child"交叉显示各五次。

这个只是可能的结果之一。

论坛徽章:
0
6 [报告]
发表于 2009-04-25 02:13 |只看该作者

回复 #3 乌龙张 的帖子

父进程结束以后返回到shell,多出来那一行是shell提示行,不是你的程序打出来的
然后子进程打出最后一行

论坛徽章:
0
7 [报告]
发表于 2009-04-25 08:43 |只看该作者
原帖由 llxxtnt 于 2009-4-25 02:13 发表
父进程结束以后返回到shell,多出来那一行是shell提示行,不是你的程序打出来的
然后子进程打出最后一行


你好,谢谢!
我知道那一行是shell提示行,我不明白的是:应该是在子进程输出最后一行之后才显示shell提示行呀。为什么在最后一行之前就有了shell提示行?

论坛徽章:
0
8 [报告]
发表于 2009-04-25 08:44 |只看该作者
原帖由 MMMIX 于 2009-4-24 23:08 发表

这个只是可能的结果之一。



我反复执行多次,一直是4楼的那种结果。而我预想的结果一次也没有出现。这应该如何解释呢?谢谢!

论坛徽章:
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
9 [报告]
发表于 2009-04-25 09:02 |只看该作者
原帖由 乌龙张 于 2009-4-25 08:44 发表



我反复执行多次,一直是4楼的那种结果。

真的?那一楼的结果是怎么来的?你现在在把你在四楼的代码重新编译一遍,然后直接执行四遍把结果贴上来我看看。

论坛徽章:
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
10 [报告]
发表于 2009-04-25 09:03 |只看该作者
原帖由 乌龙张 于 2009-4-25 08:43 发表


你好,谢谢!
我知道那一行是shell提示行,我不明白的是:应该是在子进程输出最后一行之后才显示shell提示行呀。

只要 Shell 启动的进程(也就是这里的父进程)一结束,Shell 就会打印提示符。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP