このコードを考えると:
#include <stdio.h>
#include <unistd.h>
#include <sys/types.h>
int main(void)
{
int fd[2], nbytes;
pid_t childpid;
char string[] = "Hello, world! I'm the son and this my message!\n";
char readbuffer[80];
pipe(fd); // piping fd[0] & fd[1]
if((childpid = fork()) == -1) // here we create a SON process
{
perror("fork");
exit(1);
}
if(childpid == 0) // child process
{
/* Child process closes up input side of pipe */
close(fd[0]); // closing the READ end from reading , after that the SON would write into fd[1]
/* Send "string" through the output side of pipe */
write(fd[1], string, (strlen(string)+1));
printf("Verification : Message was sent successfully by the SON!\n");
exit(0);
}
else // father process
{
/* Parent process closes up output side of pipe */
close(fd[1]);
/* Read in a string from the pipe */
nbytes = read(fd[0], readbuffer, sizeof(readbuffer));
printf("I'm the father and I received that string: %s", readbuffer);
}
return(0);
}
出力は次のとおりです。
I'm the father and I received that string: Hello, world! I'm the son and this my message!
Verification : Message was sent successfully by the SON!
私はパイプを理解しようとしていますが、はっきりしないことがいくつかあります:
息子がその行でメッセージを送信し
write(fd[1], string, (strlen(string)+1));
、その後、メッセージが送信されたことを確認するメッセージが表示された場合、父親が息子からメッセージを受信した後printf
、なぜ確認(たとえばVerification : Message was sent successfully by the SON!
)を取得するのですか?最初に息子からの確認であり、次に文字列であると想定されていませんでしたか?父親がパイプから読み込もうとし、息子がパイプに書き込みたい場合、ここのどこかにデッドロックが隠されていますね。なぜデッドロックが発生しないのですか?
ありがとう