1

我提示用户输入文件名,如果他们第一次输入有效的文件名,它会起作用。但是,如果第一次无效,则其他所有检查都会失败。我将如何解决这个问题?另外,假设他们只是指定一个目录,我将如何获取所有文本文件的名称以及有多少?

int main() {

    ifstream inFile;
    int result;
    string filename;

    cout << "If the executable is not in the same directory as the\nfile, then a directory needs to be provided\n\n";
    while (true) {
        cout << "Enter the file name:  ";
        getline(cin, filename);
        inFile.open(filename.c_str(), ios::in);

        if (!inFile)
            cout << "\n**File failed to open**\n\n";
        else break;
    }

    result = countLOC(inFile);
    cout << "\nThere are " << result << " lines of code in \"" << filename << "\"\n\n";

    inFile.close();
    return 0;
}
4

5 回答 5

3

调用clear重置调用打开之前的状态。

于 2009-05-20T22:52:29.377 回答
3

这是因为对象“inFile”中的错误位已被设置。
在执行任何其他操作之前,您需要重置错误位。

if (!inFile)
{
    cout << "\n**File failed to open**\n\n";
    inFile.clear();
}
else break;
于 2009-05-20T22:55:39.277 回答
0

您实际上不需要使用错误标志等,您只需调用 inFile.is_open() 函数进行检查。您也不需要使用 inFile.clear() 。

于 2009-05-20T22:57:56.667 回答
0

是的,做一个明确的

如果用户提供了您需要执行 FindFirst 和 FindNext 的目录

msdn.microsoft.com/en-us/library/zyzxfzac(VS.71).aspx

并以这种方式处理所有文件。

于 2009-05-20T22:58:06.557 回答
0

清除它。另外,您不需要循环中的中断,我建议您这样做:

do {
    if (infile.fail())
       cout << "\n**File failed to open**\n\n";
    infile.clear()
    cout << "Enter the file name:  ";
    getline(cin, filename);
    inFile.open(filename.c_str(), ios::in);
} while(!infile)
于 2009-05-20T23:06:08.430 回答