首页 > 解决方案 > Bash 提示出现在输出中间

问题描述

我正在解决 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;

}

这是输出

标签: linuxterminalpipeforkubuntu-16.04

解决方案


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

这可以通过wait(2)使用您创建的子进程的 pid 从您的初始进程调用来解决。


推荐阅读