将局部指针传递给函数 FatFs

passing local pointer to function FatFs

我在 C 中有以下函数:

char* AUDIO_GetFile(FIL* fil, DIR* dir, FILINFO* fno) {
    FRESULT res;
    res = f_readdir(dir, fno); /* Read a directory item */
    if (fno->fname[0] == '[=11=]')} /* End of files */
       ...
    }
    ...
    return &(fno->fname);
}

但是我需要一个临时变量来保存旧值然后 return &(fno->fname)。我创建了局部变量 FILINFO t_fno 然后将它传递给函数 res = f_readdir(dir, &t_fno); 一切正常。

但是如果我想使用 t_fno 作为本地指针然后将其传递给 f_readdir 我没有得到实际数据但是一些随机内存读数和程序在 if (t_fno->fname[0] == '[=16=]')} 上崩溃.我也尝试初始化 FILINFO* t_fno = NULL 但这没有帮助。

char* AUDIO_GetFile(FIL* fil, DIR* dir, FILINFO* fno) {
    FRESULT res;
    FILINFO* t_fno;
    res = f_readdir(dir, t_fno); /* Read a directory item */
    if (t_fno->fname[0] == '[=12=]')} /* crash */
       ...
    }
    ...
    fno = t_fno;
    return &(fno->fname);
}


FRESULT f_readdir (
    DIR* dp,            /* Pointer to the open directory object */
    FILINFO* fno        /* Pointer to file information to return */
)
{
    FRESULT res;
    DEFINE_NAMEBUF;


    res = validate(dp);                     /* Check validity of the object */
    if (res == FR_OK) {
        if (!fno) {
            res = dir_sdi(dp, 0);           /* Rewind the directory object */
        } else {
            INIT_BUF(*dp);
            res = dir_read(dp, 0);          /* Read an item */
            if (res == FR_NO_FILE) {        /* Reached end of directory */
                dp->sect = 0;
                res = FR_OK;
            }
            if (res == FR_OK) {             /* A valid entry is found */
                get_fileinfo(dp, fno);      /* Get the object information */
                res = dir_next(dp, 0);      /* Increment index for next */
                if (res == FR_NO_FILE) {
                    dp->sect = 0;
                    res = FR_OK;
                }
            }
            FREE_BUF();
        }
    }

    LEAVE_FF(dp->fs, res);
}

根据 its docsf_readdir() 期望它的第二个参数是“指向文件信息结构的指针,用于存储有关读取项目的信息。”这与您描述的第一个用途一致,您将 t_fno 声明为本地 FILINFO 结构,并传递其地址。它与将t_fno声明为指针、使其未初始化并传递其不确定的初始值一致。

第二种方法会产生未定义的行为,这似乎非常合理,因为最仁慈的解释可能是您已指示函数在某个随机位置写入数据。即使成功了,你也不知道会是什么效果,也不知道你以后再读回时数据是否不变,或者你是否可以读取它们晚点回来。 C 不要求或为您提供任何理由——它只是声明行为未定义。你不能安全或可靠地以这种方式完成工作。

如您所见,初始化指针没有帮助,除非(您没有探索)您将其初始化为指向与 FILINFO 结构兼容的实际存储。指针声明本身只提供指针,不提供指向的任何内容。示例:

char* AUDIO_GetFile(FIL* fil, DIR* dir, FILINFO* fno) {
    FRESULT res;
    FILINFO t_info;
    FILINFO* t_fno = &t_info;

    res = f_readdir(dir, t_fno); /* Read a directory item */

    // ...

在大多数情况下,我不希望单独维护 t_fno,但保留它可能有可行的理由。