Closed. This question is off-topic。它当前不接受答案。
                            
                        
                    
                
                            
                                
                
                        
                            
                        
                    
                        
                            想改善这个问题吗? Update the question,所以它是on-topic,用于堆栈溢出。
                        
                        2年前关闭。
                                                                                            
                
        
我在C中有一个程序在解析文件。它适用于较小的文件,但是,当我使用较大的文件运行它时,我遇到试图获取长度的“ TRLR”字符串,这会导致段错误。

int length = 0;
length = strlen(toParse);


在gdb中运行它,toParse等于“ TRLR”,即使在变量上运行strlen之后,长度也等于0。

GDB输出:

Breakpoint 1, initializeField (toParse=0x7fffffffe0e2 "TRLR")
    at ./src/GEDCOMutilities.c:79
79          printf("Before length = strlen(toParse\n");
(gdb) p toParse
$12 = 0x7ffffffffffe0e2 "TRLR"


编辑(显示信息来源的代码):

    fgets(buffer, 255, file);
    //Check if it's a number between 0-99
    if ((isdigit(buffer[0])) || (isdigit(buffer[0] && isdigit(buffer[1])))) {
        //Get the number and store into toParse
        toParse = strtok(buffer, " ");
        int num = atoi(toParse);

        //Create and initialize a new structure with the line's other information
        StructureToStoreInto* tempStructure = initialize(toParse);


本质上,我正在从文件中获取一行,该文件应具有以下结构:
数字标签/参考值
因此,我检查以确保该数字介于0-99(有效数字)之间,然后将其余的行发送到初始化函数中以进行解析并存储到结构中。 (我知道正则表达式将是进行验证的简单得多的方法)

最佳答案

文件中的最后一行可能没有换行符,因此通过第一遍进行计数可以减少一个(较少)。使用fgets的惯用方式是

while(fgets(buffer, 255, file) != NULL) { ... }


但是我建议在开发过程中使用更大的缓冲区,以防止拆分一行。

关于c - 为什么strlen(“TRLR”)会导致段错误? ,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/48548553/

10-11 06:04