c - 执行strcpy时出现段错误

标签 c malloc strcpy

我已经开始学习C,并且一直在做一些小程序来学习。现在我正在处理内存指针,我有一个简单的问题。

据我了解,我在下面编写的程序导航到/proc/sys/net/ipv4/conf/目录并打印出那里列出的目录。我的目的是在函数 getSysctlNames() 中分配内存,然后在调用者 main() 中释放它。 getSysctlNames() 还应该返回它找到的目录名称的数量。我读到这不是最好的主意(在函数中分配并从调用者中取消分配),但我只是想愚弄和学习而不是遵循某种模式。我的问题是在运行 strcpy 函数时在第 55 行出现段错误。我不确定我做错了什么。任何帮助将不胜感激!

int getSysctlNames(char** namesPointer);

int main(int argc, char **argv) {
    char** namesPointer;
    int numberOfNames = getSysctlNames(namesPointer);
    printf("Number of files: %i\n", numberOfNames);
    int i = 0;
    for (i = 0; i <= numberOfNames; i++) {
        printf("%s\n", namesPointer[i]);
        free(namesPointer[i]);

    }
    free(namesPointer);
    return 0;
}

int getSysctlNames(char** namesPointer) {
    int numberOfNames = 0;
    DIR *directory = opendir("/proc/sys/net/ipv4/conf/");
    if (directory) {
        struct dirent *directoryEntry;
        while ((directoryEntry = readdir(directory)) != NULL) {
            if (strcmp(directoryEntry->d_name, ".") != 0 &&
                strcmp(directoryEntry->d_name, "..") != 0) {
                numberOfNames++;
            }
        }
        closedir(directory);
    } else {
        return -1;
    }
    if (numberOfNames == 0) return 0;
    namesPointer = (char**) malloc(numberOfNames * sizeof(char*));
    if (namesPointer == NULL) {
        return -1;
    }
    directory = opendir("/proc/sys/net/ipv4/conf/");
    if (directory) {
        struct dirent *directoryEntry;
        int i = 0;
        while ((directoryEntry = readdir(directory)) != NULL) {
            if (strcmp(directoryEntry->d_name, ".") != 0 &&
                strcmp(directoryEntry->d_name, "..") != 0) {
                namesPointer[i] = malloc((strlen(directoryEntry->d_name) + 1) * sizeof(char));
                if (namesPointer[i] = NULL) {
                    int j = i - 1;
                    while (j >= 0) {
                        free(namesPointer[j]);
                        j--;
                    }
                    free(namesPointer);
                    return 0;
                }
                printf("%s\n", directoryEntry->d_name);
                strcpy(namesPointer[i], directoryEntry->d_name);
                printf("Got to 2\n");
                i++;
            }
        }
        closedir(directory);
        return numberOfNames;
    }
    free(namesPointer);
    return -1;
}

最佳答案

您分配内存,然后用 NULL 覆盖指针值:

namesPointer[i] = malloc((strlen(directoryEntry->d_name) + 1) * sizeof(char));
if (namesPointer[i] = NULL) {...

应该是

if (namesPointer[i] == NULL)

if (!namesPointer[i])

关于c - 执行strcpy时出现段错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44253358/

相关文章:

c - 以循环方法调度 pthread

c - 无效写入 Valgrind

使用包装函数调用 Malloc

c - malloc 和 strcpy 交互

c - c中函数和变量的静态作用域使用

c - 无论如何我可以比较使用指针制作的结构的结构?

c++ - 如何在 GCC 中弃用 C 预处理器宏?

c - 访问缓冲区的内容

c - 使用 strcpy() 的结构的 char 数组成员出现段错误

c - 在C中分割字符串并分别获取每个字段