【发布时间】:2013-08-26 11:33:11
【问题描述】:
我正在尝试将文件列表存储在 char** 变量中。
scandir() 正确完成,但在尝试打印 char** 时出现分段错误。
代码如下:
int main()
{
char** fileList;
int noOfFiles;
char* path = ".";
makeList(&fileList, &noOfFiles, path);
return 0;
}
void makeList(char ***fileList, int* noOfFiles, char* path){
struct dirent **fileListTemp;
*noOfFiles = scandir(path, &fileListTemp, NULL, alphasort);
int i;
fileList = (char***)malloc(sizeof(char***));
*fileList = (char**)malloc(*noOfFiles * sizeof(char*));
printf("total: %d files\n",*noOfFiles);
for(i = 0; i < *noOfFiles; i++){
*fileList[i] = (char*)malloc(strlen(fileListTemp[i] -> d_name) *sizeof(char));
strcpy(*fileList[i], fileListTemp[i] -> d_name);
printf("%s\n",*fileList[i]);
}
return;
}
这会在打印 2 个文件名后出现分段错误。
输出:
总共:27 个文件。
..
.j.v
分段错误(核心转储)
【问题讨论】:
-
不需要强制转换分配的内存?请详细说明。
-
那个链接有一个很好的解释。关于您的问题,您传入
char ***fileList(指向已声明变量的指针,即main中的char **fileList),然后直接写入堆栈上的值。你的意思是说*fileList = malloc(sizeof(char**))?对不同级别的指针使用相同的名称会很快造成混淆。 -
*fileList = malloc(sizeof(char**))实际上是的。但是我不需要指定否。这将包含的字符串?我知道每个指针的深处都只存储一个内存位置,但没有字符串必须存储在某个地方......? -
在您的作业到期之前,我无法为您提供帮助,抱歉。我有一些建议: (1) 对指针的“级别”使用不同的名称(不要声明
int *i,然后在签名中使用int **i); (2) 为了清楚起见,考虑makeList中的一个临时变量来保存新分配的指针; (3)在纸上用方框和箭头勾勒出你的每一项作业都应该用来确保你正确间接的地方; (4) 使用简化 C 约定,例如不强制转换malloc并且从不说sizeof(char)(根据定义始终为 1)。
标签: c linux string malloc scandir