2

読み取りにパイプしようとしていますが、2番目の入力後もsegfaultingを続けます。私は何が間違っているのですか?前もって感謝します。

 $ ./read < <(python -c 'print "BBA\nBBADD\n",')
 Please enter your first name: 
 buf=
 BBA
 BBA
 Please enter your last name: 
 buf=
 Segmentation fault (core dumped)

参照としてreadのコードを添付しました。重要な部分はread()です。

//read.c
#include <stdio.h>
#include <string.h>

void prompt_name(char *name, char *msg){
    char buf[4096];

    puts(msg);

    read(0, buf, sizeof buf);
puts("buf=");
puts(buf);
    *strchr(buf, '\n') = 0;

puts(buf);
    strncpy(name, buf, 20);
puts(name);
}

void prompt_full_name(char *fullname) {
    char last[20];
    char first[20];

    prompt_name(first, "Please enter your first name: ");
    prompt_name(last, "Please enter your last name: ");

    strcpy(fullname, first);
    strcat(fullname, " ");
    strcat(fullname, last);
}


int main(int argc, char **argv){
    char fullname[42];

    prompt_full_name(fullname);
    printf("Welcome, %s\n", fullname);

    return 0;
}

`

4

1 に答える 1

4

read文字列については何も知らないので、sizeof(buf)NULで終了することなく文字を楽しく読み取ることができますbuf。その後、呼び出すputs(buf)と未定義の動作が発生します。

単純な文字列I/Oにこのような低レベルの関数を使用するべきではありません。getline代わりに好む。を使用したい場合はread、小さいチャンクを読み取り、すべての呼び出しで戻り値を確認して使用します。どれだけ読んだかがわかります。

于 2012-11-08T14:57:39.490 に答える