如何在c中正确使用scandir()?
作者:互联网
我试图在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个文件名后,这会出现分段错误.
输出:
total: 27 files.
..
.j.v
Segmentation fault (core dumped)
解决方法:
函数scandir()为您分配内存.
您不需要分配任何内存.你需要释放scandir()返回给你的内存.
你的代码调用:* noOfFiles = scandir(path,& fileListTemp,NULL,alphasort);
返回时,noOfFiles将包含路径目录中的目录条目数,fileListTemp将指向已分配字符串的已分配指针数组,每个指向的字符串指向包含文件的以空值终止的名称的已分配块.
如果您的目录包含文件“FirstFile.txt”,“AnotherFile.txt”,“ThirdFile.txt”,例如,通过您的调用,从scandir()返回时,noOfFiles将被设置为5,用于三个文件加上两个更多的是“.”和“..”目录条目.如果您不通过’alphasort’,那么参赛作品将不会有任何特定的订单. (实际上这有点不正确.它们将按目录文件名条目的顺序排列,这取决于最初创建文件的顺序.)
因为您传递了’alphasort’,您应该按以下顺序看到条目(我明确地显示了null-byte-string-terminator:
fileListTemp[0] == ".\0"
fileListTemp[1] == "..\0"
fileListTemp[2] == "AnotherFile.txt\0"
fileListTemp[3] == "FirstFile.txt\0"
fileListTemp[4] == "ThirdFile.txt\0"
所以fileListTemp指向一个包含五个(char *)指针的已分配内存块.五个(char *)指针中的每一个都指向一个包含空终止目录条目名称的已分配内存块.
那是分配内存的SIX块.
您可以使用此分配的内存,直到完成它为止,然后在数组中的EACH条目上调用free(),然后调用数组本身的free().
你必须释放每个条目以及数组本身.它们都是独立分配的内存块.
完成列表后,您应该:
for (int i = 0; i < noOfFiles; i++)
{
free(fileListTemp[i];
}
free(fileListTemp);
标签:c-3,linux,malloc,string,scandir 来源: https://codeday.me/bug/20190712/1437947.html