0

对 C 编程非常陌生。我正在编写一个程序,我想提示用户输入要打开以供阅读的文件的名称。在下面显示的代码中,如果它没有打开或文件不存在,我想抛出一个错误,但是当我运行它时,我的代码会爆炸,我必须关闭程序(DOS)

/*ask user for the name of the file*/
  printf("enter file name: ");
  gets(fname);


//Opens the file from where the text will be read. 
fp=fopen(fname, "r");

//Checks if the file us unable to be opened, then it shows the error message 
if (fp == NULL)
    {
     printf("\nError, Unable to open the file for reading\n");
    }

// 你可以通过创建一个 name.txt 文件来测试它。如果您需要更多信息,请告诉我。

4

3 回答 3

5

好吧,你应该确保有足够的空间fname来存储你的文件名,否则你几乎肯定会导致损坏和“炸毁”:-)

例如,以下代码段:

char fname[10];
gets (fname);

如果您输入的信息多于fname无法容纳的信息,将会出现问题。那时,您进入了未定义的行为领域,任何事情都可能发生。

但是,由于gets无法限制用户输入的内容,因此您永远不应该使用它!

可以在此答案中找到一种适当的、受保护的用户输入方法。

它使用fgets,因为这可以限制用户输入的内容。它还允许提示,在出现问题时提供错误指示,正确处理文件结尾,并删除任何过大行的其余部分,使其不会影响下一个输入操作。

事实上,我会在这里复制它以使这个答案自成一体:

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

#define OK       0
#define NO_INPUT 1
#define TOO_LONG 2
static int getLine (char *prmpt, char *buff, size_t sz) {
    int ch, extra;

    // Get line with buffer overrun protection.
    if (prmpt != NULL) {
        printf ("%s", prmpt);
        fflush (stdout);
    }
    if (fgets (buff, sz, stdin) == NULL)
        return NO_INPUT;

    // If it was too long, there'll be no newline. In that case, we flush
    // to end of line so that excess doesn't affect the next call.
    if (buff[strlen(buff)-1] != '\n') {
        extra = 0;
        while (((ch = getchar()) != '\n') && (ch != EOF))
            extra = 1;
        return (extra == 1) ? TOO_LONG : OK;
    }

    // Otherwise remove newline and give string back to caller.
    buff[strlen(buff)-1] = '\0';
    return OK;
}

您可以按如下方式调用它,指定缓冲区和大小,并在返回时接收错误指示:

// Test program for getLine().

int main (void) {
    int rc;
    char buff[10];

    rc = getLine ("Enter string> ", buff, sizeof(buff));
    if (rc == NO_INPUT) {
        // Extra NL since my system doesn't output that on EOF.
        printf ("\nNo input\n");
        return 1;
    }

    if (rc == TOO_LONG) {
        printf ("Input too long [%s]\n", buff);
        return 1;
    }

    printf ("OK [%s]\n", buff);

    return 0;
}
于 2012-04-11T04:03:16.817 回答
0

好吧,这就是我发生的事情,为“if”添加一个“else”条件对我有用。下面提到的是代码。

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

int  main() 
{

char fname[100];
FILE* fp;
memset(fname, 0, 100);
/*ask user for the name of the file*/
printf("enter file name: ");
gets(fname);

fp = fopen(fname, "r");

//Checks if the file us unable to be opened, then it shows the error message 
if (fp == NULL)
{
    printf("\nError, Unable to open the file for reading\n");
}

else
{
    printf("hello");
}


getch();
}

还要确保您已将“#include”添加为头文件。

于 2014-09-20T15:30:17.930 回答
0

不确定您缺少什么,但是该程序可以在命令行上使用 cl.exe 为我编译和运行。

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

int main(){
    char fname[100];
    FILE* fp;
    memset(fname, 0, 100);
    /*ask user for the name of the file*/
    printf("enter file name: ");
    gets(fname);


    //Opens the file from where the text will be read. 
    fp = fopen(fname, "r");

    //Checks if the file us unable to be opened, then it shows the error message 
    if (fp == NULL)
    {
        printf("\nError, Unable to open the file for reading\n");
    }

}

另请注意,某些编译器(包括 Microsoft 的)要求您在使用默认选项调用时将所有声明放在函数的顶部。

于 2012-04-11T04:02:22.383 回答