Bash提示出现在输出的中间

时间:2019-01-07 14:28:44

标签: linux terminal pipe fork ubuntu-16.04

我正在Ubuntu 16.04中用C处理fork()和pipe()的问题,输出应该是150个整数的排序数组。输出是所需的,但是bash提示出现在输出的中间。每次都是随机的。我在任何地方都找不到这种情况的参考。我不知道这是因为我的代码还是其他原因。你能告诉我原因吗?这是我的代码。 bubbleSort是通常的气泡排序功能。

int main(){
int pd1[2], pd2[2], pd3[2], pd4[2], j=0;
int p, ABC[50],D1[50],D2[50], i,D[100], E[150];


if(pipe(pd1)<0){
    printf("Pipe1 creation failed!!...\nExiting...");
    exit(1);
}
if(pipe(pd2)<0){
    printf("Pipe2 creation failed!!...\nExiting...");
    exit(1);
}
if(pipe(pd3)<0){
    printf("Pipe3 creation failed!!...\nExiting...");
    exit(1);
}
if(pipe(pd4)<0){
    printf("Pipe4 creation failed!!...\nExiting...");
    exit(1);
}

p=fork();
if(p<0){
    printf("Fork creation failed!!...\nExiting...");
    exit(1);
}



srand(time(NULL)+p);
for(i=0;i<50;i++){
    ABC[i]=rand()%1000;
}
bubbleSort(ABC,50);
if(!p)
    write(pd1[1],ABC,sizeof(ABC)+1);
else{
    write(pd2[1],ABC,sizeof(ABC)+1);
    if(fork()==0){
        for(i=0;i<50;i++)
            ABC[i]=rand()%1000;
        bubbleSort(ABC,50);
        write(pd3[1],ABC,50);
        if(fork()==0){
            read(pd1[0],D1,sizeof(D1));
            read(pd2[0],D2,sizeof(D2));
            //close(pd1[0]); close(pd1[1]); close(pd2[0]); close(pd2[1]);
            for(i=0;i<50;i++){
                D[i]=D1[i];
                D[i+50]=D2[i];
            }
            bubbleSort(D,100);
            write(pd4[1],D,sizeof(D)+1);
            if(fork()==0){
                read(pd3[0],ABC,sizeof(ABC));
                read(pd4[0],D,sizeof(D));
                //close(pd3[0]); close(pd3[1]); close(pd4[0]); close(pd4[1]);
                for(i=0;i<100;i++)
                    E[i]=D[i];
                for(i=0;i<50;i++)
                    E[i+100]=ABC[i];
                bubbleSort(E,150);
                for(int i=0;i<150;i++)
                    printf("%d %d\n",i,E[i]);       
            }
        }

    }
}
return 0;

}

This is the output

1 个答案:

答案 0 :(得分:0)

您的程序正在创建子进程,但是在允许其自身退出之前,它不会等待它们完成。这意味着即使您的初始过程结束后,它们仍会继续工作,并且您的外壳会继续运行并打印提示。

可以通过在初始过程中使用创建的子进程的pid调用wait(2)来解决此问题。