2

更新:正确初始化字符串char string[sizeof buffer - 1]已经解决了崩溃问题,但我仍然很好奇有多个标点符号与它有什么关系!

我正在尝试从“某些文本”形式的文件中读取字符串。到目前为止,使用sscanf该模式\"%[^\"]\"对我来说非常有效,但是一旦我开始在字符串中添加标点符号,程序就开始崩溃。

似乎只有在使用多个标点符号时才会出现错误,无论它是什么标点符号或标记的位置。无论文件中带有标点符号的行的位置如何,它也会发生(即,即使最后一行没有标点符号,错误仍然会发生)。

无论如何,下面是我到目前为止的代码:

char* func(char* f_name);
    FILE* file = get_file(f_name,"r"); // a short function I wrote to get the
                                       // file pointer from the current
                                       // directory. The error is almost
                                       // certainly not here.
    if (file == 0) {
        print("Unable to load file\nExiting...");
        exit(-1);
    }

    char* pattern = "\"%[^\"]\"";
    int read_args = -1;
    char* string; //  string size is unknown until read
    char buffer[1200]; // i expect very long line of data in the file

    while ( fgets( buffer, sizeof(buffer), file ) != NULL ) {
        printf("found line: %s\n",buffer);
        read_args = sscanf(buffer, pattern, string);
        printf("num args: %d\n",read_args);
        printf("read value: %s\n", string);
    }

    fclose(file);
    return string;
}

以下是我尝试过的一些数据。在标记为“不成功”的地方,程序编译、运行所有内容,并在退出前崩溃。

"test test test" // successful
"test, test test" // successful
"test test; test" // successful

"test, test, test" // unsuccessful
"test; test. test," // unsuccessful

如果此问题得到解决,我计划使用更复杂的模式,并且在%d \"%[^\"]\" \"%[^\"]\"发生此错误之前成功地使用该模式读取数据。提前感谢您的任何答案。

4

1 回答 1

3

您的代码会调用未定义的行为,因为您正在扫描到随机内存。

string变量从未初始化,因此写入的字符串的目的地sscanf()是未定义的。

你需要例如

char string[sizeof buffer - 1];

它并不总是崩溃的事实只是运气,代码一直在调用未定义的行为。根据您的示例,可能只是标点符号,扫描的文本更长,因此覆盖了更多的内存,一旦碰到足够重要的东西,最终就会触发崩溃。

于 2012-01-14T17:24:55.277 回答