我正在编写的程序中的结构有点问题。背景; 我正在 ARMv7 芯片上用 C 语言开发代码。该系统有一个带有 FAT16 文件系统的 SD 卡,用于文件访问。我正在使用一个用于 FAT16 文件读写操作的库来处理文件输出/输入的任何工作。目前我在主函数之前全局声明一个结构;
struct config_information
{
char *name;
//version
char *fwversion;
//IP address
char *ip;
};
//Declare structs for config information
struct config_information config;
struct config_information loadedconfig;
指针用于字符串。例如,我使用 &config.name 将数据读入这些变量。我必须使用我编写的函数将通过串行端口接收的字符读入另一个指向 strcat 到另一个的字符指针,但这可以正常工作,并且我已经验证了用户输入的详细信息与记录的输入相匹配(有一个快速如果有人想知道,终端窗口上的提示屏幕会提示详细信息)。
然后我实现提供的库函数以将结构保存到文件中;
fat16_write_file(CONF_FILE,&config, READBUFSIZE);
其中 CONF_FILE 只是要使用的文件的文件句柄,&config 是输出缓冲区,READBUFSIZE 是缓冲区的大小(定义为 148,对我的目的来说足够大,但后来我希望更改它以计算结构的大小输出,然后计算文件大小以便能够正确读取它)。我已经添加了库提供的函数定义以及最后的开场白,以供参考,以防我不清楚。
这完美地工作,文件中的输出是;Name1.1 192.168.1.1 有很多空格。显然,我输入 Name 作为名称,1.1 作为固件,IP 是不言自明的。
我天真地以为我可以反过来将它读回我用这个声明的 loadconfig 结构;
fat16_read_file(CONF_FILE,&loadedconfig,READBUFSIZE);
显然,这没有希望工作,因为结构没有任何预定义的大小来知道要读回多少。
那么,我怎样才能将我保存的数据读回到它来自的同一个结构中呢?这个名字可以是任何大小,不是很大,但不能安全地预测。FW 版本永远只会是#.#,并且 IP 显然在已经定义的限制内。
感谢您在正确方向上的任何提示或轻推。请询问您是否需要更多信息来了解范围。
以供参考;
/**
* \ingroup fat16_file
* Reads data from a file.
*
* The data requested is read from the current file location.
*
* \param[in] fd The file handle of the file from which to read.
* \param[out] buffer The buffer into which to write.
* \param[in] buffer_len The amount of data to read.
* \returns The number of bytes read, 0 on end of file, or -1 on failure.
* \see fat16_write_file
*/
int16_t fat16_read_file(struct fat16_file_struct* fd, uint8_t* buffer, uint16_t buffer_len)
/**
* \ingroup fat16_file
* Writes data to a file.
*
* The data is written to the current file location.
*
* \param[in] fd The file handle of the file to which to write.
* \param[in] buffer The buffer from which to read the data to be written.
* \param[in] buffer_len The amount of data to write.
* \returns The number of bytes written, 0 on disk full, or -1 on failure.
* \see fat16_read_file
*/
int16_t fat16_write_file(struct fat16_file_struct* fd, const uint8_t* buffer, uint16_t buffer_len)