c程序的意外行为,试图从K& R

时间:2016-01-06 19:39:44

标签: c kernighan-and-ritchie

练习6-2。编写一个读取C程序的程序,并按字母顺序打印每组 变量名在前6个字符中相同,但之后不同。别算 字符串和注释中的单词。使6成为可以从命令行设置的参数。 (来自K& R)

我开始练习这个练习,而且我一开始就被困住了。我试图获取整个输入并在数组中逐行保存,然后将数组中的指针指向保存的行。后来我想到为每个单词分配空间并将它们写到一棵树上。但是,在我输入以下代码时输入:

  

abc def;'Ctrl-Z'

#include <stdio.h>
#include <ctype.h>
#include <string.h>

#define MAXLINE 100
#define MAXWORDS 10

int read_input(char *[]);

int main(int argc, char *argv[])
{
    char *variables[MAXWORDS] = {0};
    int i;
    int tmp;


    while((tmp = read_input(variables)) != EOF){
        for(i=0; i < tmp; i++){
            printf("%s ",*(variables+i));
        }
    }


    return 0;
}


/* read_input: mapping all the input words into *variables[], and returning the number of the words + 1 */
int read_input(char *variables[]){
    static char s[MAXLINE];
    int tmp;
    int i, j;

    i = 0;
    if((tmp = getline(s, MAXLINE)) == EOF)
        return EOF;

    for(j = 0; j < MAXWORDS && s[i] != '\0'; j++){ /* it does'nt work when j = MAXWORDS because the rest of the line is not saved */
        while(!isalpha(s[i]))
            i++;
        *(variables+j) = &s[i];
        while(isalnum(s[i]) || s[i] == '_')
            i++;
        if(s[i] == '\0')
            continue;
        s[i++] = '\0';
    }
    return j;
}

/* getline: read a line into s, return length */
int getline(char *s,int lim)
{
    static char end; /* static typed char that saves if the last not saved 'c' was an EOF */
    char c;
    int i;
    if(end == EOF){ /* the last input character was an EOF */
        end = 0;
        return EOF;
    }
    for (i=0; i < lim-1 && (c=getchar())!=EOF && c!=';'; ++i)
        s[i] = c;
    s[i] = '\0';
    if(i > 0 && c == EOF)
        end = EOF;
    else if(i == 0 && c == EOF){
        printf("!");
        return EOF;
    }
    else
        return i;

}

程序不会立即停止,主要的while循环会要求另一个输入......我做错了什么?

1 个答案:

答案 0 :(得分:0)

你没有做错任何事。由于C stdio库函数的通常设计,只有在没有前面的未读输入时才会识别EOF,因此您必须键入 Enter Ctrl - Z Ctrl - Z Ctrl - Z