0

次のコードのいくつかの行を理解するのに大きな問題があります (コメントでマークされた番号):

最初 - 入力データで配列を埋めるループのコード:

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 するのですか? ほとんどの場合、この条件が満たされているため、入力されたすべての数値を拒否することになりますか?

答えてくれてありがとう!

4

1 に答える 1

1
  1. そうではなく、他のライブラリで行ったとしても、これらの2つの関数ではありません
  2. いいえ。単にゼロを返し、整数を初期化しないままにします (このケースはループで処理されません)。
  3. どう言う意味ですか?これは、数字から整数を計算する方法です。
  4. 関数が読み取って処理したばかりの整数の末尾にある文字だけになります。ungetch文字がなく、ストリームの終わりが でマークされている場合を除きますEOF。そのマーカーはバッファーに返されません。
于 2012-08-13T22:10:04.897 に答える