将局部指针传递给函数 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 docs,f_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
,但保留它可能有可行的理由。
我在 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 docs,f_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
,但保留它可能有可行的理由。