realloc()突然中止C程序

时间:2014-08-26 03:13:49

标签: c unix realloc

请注意,我已经完成了

Facing an error "*** glibc detected *** free(): invalid next size (fast)"

但是,我没有发现它有用。

我想动态创建一个字符串数组,文件名为字符串。

这是我的代码:

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


int main(int argc, char* argv[])
{  
    DIR         *dir = NULL;
    struct dirent   *file = NULL;
    int         i = 0;
    unsigned short  len;

    if ( (dir = opendir(".") ) == NULL ) {
        if (errno != 0) {
            perror("Unable to open current directory");
            exit(EXIT_FAILURE);
        }
    }

    char    **filename = NULL;

    while ( (file = readdir(dir)) != NULL ) {

        if (i == 0) 
            filename = malloc(sizeof(char*)*(i+1));     
        else 
            filename = realloc(filename,i+1);


        filename[i] = strdup (file->d_name);
        printf("%s  ", filename[i] );
        i += 1;
    } 
    if ( errno != 0 ) {
        perror("Unable to read from the current directory");
        exit(EXIT_FAILURE);
    } 

    if (dir != NULL) {
        if (closedir(dir) == -1) {
            if (errno != 0) {
                perror("Unable to close the current directory");
                exit(EXIT_FAILURE);
            }
        }
    } 
    printf("\n");
    return 0;
}

这是输出

*** Error in `./a.out': realloc(): invalid next size: 0x00000000016d6050 ***
realloc.c  StackOverflow  a.out  num_ip_using_scanf.c  Aborted

最初对于少数文件来说它做得很好,但突然间它因上述错误而中止。

非常感谢任何帮助。

1 个答案:

答案 0 :(得分:3)

错误的重新分配。

// filename = realloc(filename, i+1);
filename = realloc(filename,(i+1) * sizeof *filename);`

BTW:无需区分内存分配调用。由于指针初始化为NULL,因此请在第一次和以后的时间使用realloc()

char **filename = NULL;
...
// if (i == 0) filename = malloc(sizeof(char*)*(i+1));     
// else filename = realloc(filename,i+1);
filename = realloc(filename,(i+1) * sizeof *filename);`

@PaulMcKenzie指出代码应检查问题返回值。此外,fileanme最终应为free()