-1

動的に割り当てられた配列を出力すると、セグメンテーション エラーが発生します。私は動的に割り当てられた配列に慣れていないので、これが問題になる可能性があります。配列の各要素を出力している for ループをコメントアウトすると、プログラムは正常にコンパイルされます。したがって、私の readText 関数は問題ないように感じますが、間違っている可能性があります。この質問をする前に調査を行いましたが、答えが見つかりません。text1 配列の各要素を出力できるようにする必要があるだけです。これが私のコードです:

#include <stdio.h>
#include <stdlib.h>
int main(int argc, char *argv[])
{
    int ch1, ch2;
    int size1, size2;
    FILE *fh1, *fh2;

    if( argc<3 ) {
        printf("need two file names\n"); return(1);
    }
    if(!(fh1 = fopen(argv[1], "r"))) {
        printf("cannot open %s\n",argv[1]); return(2);
    }
    if(!(fh2 = fopen(argv[2], "r"))) {
        printf("cannot open %s\n",argv[2]); return(3);
    }
    if(argc>3) {
        if(!(fh3 = fopen(argv[3], "w+"))) {
            printf("cannot open %s\n",argv[3]); return(4);
        }
    }
    fseek(fh1, 0, SEEK_END);
    size1 = ftell(fh1);//Getting fh1 size
    fseek(fh1, 0, SEEK_SET);

    fseek(fh2, 0, SEEK_END);
    size2 = ftell(fh2);//Getting fh2 size
    fseek(fh2, 0, SEEK_SET);

    char* readText(int, FILE*);//declaring function
    char *text1 = readText(size1, fh1);
    int i;
    for (i=0; i<size1; i++)
      printf("text1[%d] = %s\n", i, text1[i]);
    return 0;
}
char *readText(int size, FILE *fh)//reads file into a dynamically allocated array
{
  char * text = malloc(size * sizeof(char));
  int i=0;
  while(!(feof(fh)))
    {
      fgets(text, size, fh);
      ++i;
    }
  return text;
}
4

2 に答える 2

2

text1[i]文字列ではなく単なる文字です。%s文字列の先頭へのポインタが必要なので、

printf( "text[%d] = %c\n", i, text1[i] );
于 2013-10-30T22:59:33.983 に答える