この方法で文字列の配列を初期化できることはわかっています。
static const char *BIN_ELEMENTS[5] = {
"0000\0", // 0
"0001\0", // 1
"0010\0", // 2
"0011\0", // 3
"0100\0", // 4
};
しかし、私はそれを動的な方法で達成する必要があります。ファイルから文字を読み取り、配列に挿入します。次に、その配列を文字列の配列にコピーします (上記のように)。
ファイルから次の文字をキャプチャし、次のように配列に挿入したとします。
char number[5];
char *listOfNumbers[10];
number[0]='1';
number[1]='2';
number[2]='3';
number[3]='4';
number[4]='\0';
ここで、number の内容全体を // にコピーしたいと思います。これは、listOfNumers[0]
"1234" を listOfNumers の位置 0 に格納したことを意味します。異なる数値を格納するために、さらに 9 つの位置を残します。
だから私はこのようなことをします:
listOfNumers[0] = number; //this actually seems to work.
しかし、数字の巨大なファイルであるため、新しい数字を抽出するには、配列番号を再利用する必要があります。しかし、それを行うと、以前に listOfNumers[0] に保存されていたコンテンツが上書きされ、新しい番号の新しい位置が更新されました。どうすれば対処できますか?
これが私がこれまでに持っているものです:
char number[5]; // array for storing number
int j=0; // counter
int c; // used to read char from file.
int k=0; // 2nd counter
char*listOfNumbers[10]; // array with all the extracted numbers.
FILE *infile;
infile = fopen("prueba.txt", "r");
if (infile) {
while ((c = getc(infile)) != EOF) {
if(c != ' ' && c != '\n')
number[k] = c;
++k;
} // end inner if
else {
number[k] = '\0';
listOfNumbers[j] = number;
printf("Element %d is: %s\n", j, listOfNumbers[j]); // prints correct value
++j;
k=0;
} // end else
} // end while
fclose(infile);
} // end outer if
printf("\nElement 0 is: %s\n", listOfNumbers[0]); // fails - incorrect value
printf("Element 1 is: %s\n", listOfNumbers[1]); // fails - incorrect value
printf("Element 2 is: %s\n", listOfNumbers[2]);