C - 为什么将元素分配给动态分配数组的第一个元素总是不返回任何内容

问题描述

我正在开发一个应用程序,我需要从 SD 卡读取一些文件。一切都在带有 FatFS 的 STM32 微控制器上运行。我只是打开根目录,并遍历该目录中的每个元素并检查它是文件还是文件夹,我保存了我拥有多少文件的信息。然后我为所述文件分配给定的内存量(名称文件数 x 缓冲区)。接下来,我再次读取目录,就像在第一步中一样。这次我将每个文件名称复制到内存中的上述位置。我的问题是,每次我将任何内容复制到 2D 数组时,第一个元素实际上不包含任何内容文件名从第二个索引开始。我做错了什么?

//Returns 0 on error or no files
uint8_t files_get_card_file_count(void)
{
    auto uint8_t file_count = 0;
    auto FRESULT result;
    auto DIR directory;
    auto FILINFO info;

    //Read card contents
    if(f_opendir(&directory,"/")) return 0;

    //Check if there is a card mounted and functioning
    if(disk_status(0) == (STA_NOINIT || STA_NOdisK)) return 0;

    for (;;)
    {
        result = f_readdir(&directory,&info);              // Read a directory item
        if (result != FR_OK || info.fname[0] == 0) break;  // Break on error or end of dir
        if (!(info.fattrib & AM_DIR)) ++file_count;
    }
    return file_count;
}
//Make sure we dont allocate more than MAX_FILE_COUNT blocks
char** files_mem_allocate(uint8_t file_count)
{
    auto uint8_t i;

    char **array;
    array = calloc(file_count,sizeof(char *));

    if(array == NULL) return 0;

    for(i=0; i < file_count; i++)
    {
        array[i] = calloc(MAX_FILENAME_LENGTH,sizeof(char));
        if(array[i] == NULL) return 0;
    }

    return array;
}
uint8_t files_get_names(char** array,uint8_t file_no)
{
    auto uint8_t i;
    auto FRESULT result;
    auto DIR directory;
    auto FILINFO info;

    //Read card contents
    if(f_opendir(&directory,"/")) return 1;

    //Check if there is a card mounted and functioning
    if(disk_status(0) == (STA_NOINIT || STA_NOdisK)) return 1;

    for(i=0;i<file_no;i++)
    {
        result = f_readdir(&directory,&info);              //Read a directory item
        if (result != FR_OK || info.fname[0] == 0) break;  // Break on error or end of dir
        if (!(info.fattrib & AM_DIR))
        {
            //It is a file.
            //Mind the string safety?
            //Check bounds!
            strcpy(array[i],info.fname);
        }
    }
    return 0;
}

如果我这样做: lcd_str_XY(0,1,file_names_array[0]); 记忆中这个地方什么都没有 lcd_str_XY(0,file_names_array[1]); 打印第一个文件

解决方法

files_get_names 不再考虑 f_opendir 也返回目录。事实上,根据您的描述,它很可能会返回一个目录作为第一个条目。然而 files_get_names 仍然增加索引并继续。

像这样修复它:

uint8_t files_get_names(char** array,uint8_t file_no)
{
    auto uint8_t i;
    auto FRESULT result;
    auto DIR directory;
    auto FILINFO info;

    //Read card contents
    if(f_opendir(&directory,"/")) return 1;

    //Check if there is a card mounted and functioning
    if(disk_status(0) == (STA_NOINIT || STA_NODISK)) return 1;

    i = 0;
    for(;;)
    {
        result = f_readdir(&directory,&info);              //Read a directory item
        if (result != FR_OK || info.fname[0] == 0) break;  // Break on error or end of dir
        if (!(info.fattrib & AM_DIR))
        {
            //It is a file.
            //Mind the string safety?
            //Check bounds!
            strcpy(array[i],info.fname);
            i++;
        }
    }
    return 0;
}

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...