次のコードのいくつかの行を理解するのに大きな問題があります (コメントでマークされた番号):
最初 - 入力データで配列を埋めるループのコード:
int n, array[SIZE], getint(int *);
for (n = 0; n < SIZE && getint(&array[n]) != EOF; n++)
;
関数定義は次のとおりです。
/* getint: get next integer from input into *pn */
int getint(int *pn)
{
int c, sign;
while (isspace(c = getch())) /* skip white space */
;
if (!isdigit(c) && c != EOF && c != '+' && c != '-') {
ungetch(c); /* [1] */ /* it is not a number */
return 0; /* [2] */
}
sign = (c == '-') ? -1 : 1;
if (c == '+' || c == '-')
c = getch();
for (*pn = 0; isdigit(c); c = getch())
*pn = 10 * *pn + (c - '0'); [3]
*pn *= sign;
if (c != EOF) /* [4a] */
ungetch(c); /* [4b] */
return c;
}
#define BUFSIZE 100
char buf[BUFSIZE]; /* buffer for ungetch */
int bufp = 0; /* next free position in buf */
int getch(void) /* get a (possibly pushed-back) character */
{
return (bufp > 0) ? buf[--bufp] : getchar();
}
void ungetch(int c) /* push character back on input */
{
if(bufp >= BUFSIZE)
printf(" ungetch too many characters\n");
else
buf[bufp++] = c;
}
そう:
[1] ここで同様の投稿を読みました。このような不要な文字を取り戻すと、何らかの形でバッファがブロックされるため、別の関数を使用してクリアする必要があります。が K&R に含まれておらず、著者がそれを使用する必要性について言及していないのは奇妙ですか?
[2] なぜ 0 を返すのですか? それは main() プログラム全体を停止しますか? それとも単に配列に 0 を入れますか? ( getint(&array[n] ) ?
[3] 「大きな数」を計算するためにそのような式を実装する必要があるのはなぜですか? その関数は次々に数字を取得するだけなので(getwordではなくgetchar)、いくつかの単一の整数を使用して「大きな数字」を作成します。
[4a][4b] c != EOF の場合、なぜ unetch するのですか? ほとんどの場合、この条件が満たされているため、入力されたすべての数値を拒否することになりますか?
答えてくれてありがとう!