質問
私は小さなプログラムを書いています、そして、ここにそれがすべきことがあります。
主なプロセスでは、新しいプロセスを作成する必要があり、Printf(「テキスト」)のみを行う別のプログラムを実行する必要があります。 stdoutでパイプ書き込みの端をリダイレクトしたいので、メインプロセスはそのパイプの読み取りから読み、stdoutに印刷する必要があります。私はコードを書きましたが、親のプロセスがパイプから読み込もうとすると、何度も何度もセグメンテーション障害が得られます。
#include <sys/types.h>
#include <stdio.h>
#include <string.h>
#include <unistd.h>
#include <stdlib.h>
void write_to(FILE *f){
char buf[50];
fprintf(f,"KOMA");
}
int main(){
int cpPipe[2];
int child1_fd;
int child2_fd;
if(pipe(cpPipe) == -1){
fprintf(stderr,"ERROR PIPE creation");
exit(1);
}else{printf("pipe couldn't be created\n");}
child1_fd = fork();
if(child1_fd < 0){
fprintf(stderr, " CHILD creation error");
exit(1);
}
if(child1_fd == 0){
printf("*CHILD*\n");
char program[] = "./Damn";
int dupK;
printf("stdout %d \n", STDOUT_FILENO);
printf("stdin %d \n", STDIN_FILENO);
printf("pipe1 %d \n", cpPipe[1]);
printf("pipe0 %d \n", cpPipe[0]);
// closing pipe write
close(cpPipe[0]);
close(1);
dup(cpPipe[1]);
printf("and");
close(cpPipe[1]);
exit(0);
}else{
printf("*Parent*\n");
char *p;
char *buf;
FILE *pipe_read;
close(cpPipe[1]);
pipe_read = fdopen(cpPipe[0],"r");
while((buf = fgets(p,30,pipe_read)) != NULL){
printf("buf %s \n", buf);
}
wait();
printf("Child is done\n");
fclose(pipe_read);
exit(0);
}
}
stdoutをリダイレクトするときにパイプの書き込み端を閉じる必要がありますか?
解決
うーん、...セグメンテーションの障害の理由はこちらです:
buf = fgets(p,30,pipe_read);
Pは、本質的に重要な場所ではないポインターです。コンテンツは、実行時にスタックにあるものは何でも、初期化することはありません。使用できるメモリの塊を指すために必要です! aの返品を割り当てます malloc()
それに電話するか、それを宣言します char p[LEN]
.
編集:また、すでに開いたファイル記述子を再開しています。ドキュメントを確認してください fgets
と pipe
, 、あなたは彼らがどのように働くかについて混乱していると思います。
さて、あなたの機能の流れはちょっと混乱しています。それを明確にすることに取り組んでみてください!コードは、意図、機能のアイデアを表現することを目的としていることを忘れないでください。鉛筆と紙を使用してプログラムを整理してから、実際のコードとして書きます:)。
乾杯!
他のヒント
stdoutをリダイレクトするときにパイプの書き込み端を閉じる必要がありますか?
一般的に、はい、パイプの書き込み端が開いているプロセスがありますが、パイプを読むプロセスはEOFを取得せず、ハングするからです。もちろん、使用しないファイル記述子を閉じることも整頓されています。
あなたのコードはまた、成功パスで「パイプを作成できなかった」とも言っています。