
pid = fork(); if (!pid) { execvp(args[0], args); // 这里会创建一个路径为 path 的文件,并且会写入一些数据。 } wait(&wstatus); fd = open(path, O_RDONLY); // 读取子进程创建的文件 while ((n = read(fd, buf, BUFSIZ)) > 0) if (write(connfd, buf, n) != n) printf("write error\n"); 这段代码先 fork 一个子进程,子进程创建并写入一些数据到一个文件。
父进程通过 wait 等待子进程执行完毕,然后 open 并开始读取子进程写入的文件。
这段代码有一个问题,就是有时子进程明明写入了一些数据到文件,但父进程却读取不到任何数据,就像子进程只是创建了一个空文件一样,如果在 wait 后加一个 sleep(1)就没有这种情况,请问如何保证子进程写入文件完毕后父进程才开始读取?
1 BingoXuan 2022-09-16 14:03:58 +08:00 试一下子进程写入文件加上 O_SYNC 。我觉得这种情况不应该先创建文件,通过 fork 共享文件不会更好吗? |
2 nightwitch 2022-09-16 14:05:31 +08:00 via Android 给文件加锁,父进程 flush 以后再解锁 |
3 qemu32 OP @BingoXuan 感谢回复,子进程不是我的项目,不能去改子进程的代码,其实我是想去开发一个分布式编译系统,这个子进程就是 gcc ,父进程是需要把 gcc 编译生成的可重定位目标文件读取出来再通过网络传给客户端。 |
4 qemu32 OP @nightwitch 感谢回复,能说的再具体一点吗? |
5 codehz 2022-09-16 14:14:29 +08:00 (linux 的话,可以要求 gcc 生成文件到 /dev/stdout 的,然后你直接 pipe 一下就可以接收了 |