FIFO とselect()
システム コマンドを使用してテストを実行しています。アイデアは次のとおりです。
select()
プロセス 1 は、コマンドで FIFO からのメッセージを待機してスリープする必要があります- メッセージが来ない場合、プロセス 1 は 5 秒ごとに起動し、「まだ何もありません」と言う必要があります。
- メッセージが着信した場合は、ウェイクアップし、メッセージを出力してから終了する必要があります
コードは次のとおりです注:スペースを節約するためにエラーチェックを削除しています:
//process 1's code
int main()
{
int fd, ret;
fd_set rfds;
char buffer[100] = {0};
char * myfifo = "/tmp/myfifo";
struct timeval tv;
tv.tv_sec = 5; // 5 second sleep
tv.tv_usec = 0;
mkfifo(myfifo, 0666); //Make the fifo
fd = open(myfifo, O_RDONLY);
FD_ZERO(&rfds); // clear the flags
FD_SET(fd, &rfds); // set "read" on fd
while((ret = select(fd+1, &rfds, NULL, NULL, &tv)) <= 0) //should be 1 when we're ready to read
{
FD_ZERO(&rfds); //I believe we should clear/reset these every time?
FD_SET(fd, &rfds);
printf("Nothing yet...%d\n",ret);
fflush(stdout);
}
n = read(fd, buffer, 100);
printf("I got a read of %d bytes\nIt was %s\n",n, buffer);
unlink(myfifo);
return 0;
}
プロセス 1 を起動して実行したら、10 秒ほど待ってから、プロセス 2 を開始します。
//Process 2's code
int main()
{
int fd, n, ret;
fd_set rfds;
char buffer[100] = {0};
char * myfifo = "/tmp/myfifo";
fd = open(myfifo, O_WRONLY);
printf("What would you like to send?\n");
fgets(buffer, 100, stdin);
write(fd, buffer, strlen(buffer));
close(fd);
return 0;
}
私は次のようなものを見ることを期待しています:
Nothing yet...0
Nothing yet...0
I got a read of X bytes
It was <some string>
代わりに、何かを入力してプロセス 2 の Enter キーを押すまで、何も表示されません。プロセス 1 は文字列を正しく返します...しかし、ループがメッセージを出力しないのはなぜですか?