不确定我的标题是否有意义,但我想做的是从动态结构写入文件,但让这变得有点困难的是我的结构是通过引用传递的,我不知道第一个参数如何fwrite 应该看起来像。这是部分代码:
void editData(FILE* fPtr, Car* carPtr[], int* size)
{
int number = 0;
printData(carPtr, size);
while(1)
{
if ((scanf("%d", &number) == 1) && (getchar() == '\n'))
{
if ((number > 0) && (number <= *size))
{
char make[15] = "", model[15] = "";
int year = 0;
double price = 0;
if (getUserInput(make, model, &year, &price) == 1)
{
strcpy((*carPtr+number-1)->make, make);
strcpy((*carPtr+number-1)->model, model);
(*carPtr+number-1)->year = year;
(*carPtr+number-1)->price = price;
fseek(fPtr, sizeof(Car) * number-1, SEEK_SET);
fwrite(**&carPtr[number-1]**, sizeof(Car), 1, fPtr);
}
这就是我从 main 调用这个函数的方式:
FILE* db = NULL;
int choice = 0;
db = openDatabase(db);
Car* cr = NULL;
int size = 0;
loadData(db, &cr, &size);
while((choice = menuChoice()) != 5)
{
switch (choice)
{
case 1:
insertData(db, &cr, &size);
break;
case 2:
**editData(db, &cr, &size);**
break;
case 4:
printData(&cr, &size);
break;
}
}
free(cr);
fclose(db);
}
结构体的内存分配发生在不同的函数中。
如果结构是本地的,我会在 fwrite 中作为第一个参数写入
&carPtr[number-1]
但就我而言,这不起作用。
汽车声明:
struct car
{
char make[15];
char model[15];
int year;
double price;
};
最佳答案
fwrite
需要一个指向要写入的字节缓冲区的指针。
如果您有一个局部变量(包括结构体),则需要使用 & 运算符获取其地址,如下所示:
Car myCar;
fwrite(&myCar, sizeof(Car), 1, fout);
但是,如果您已经有一个指针,那么您不需要 & 运算符:
Car *myCar;
fwrite(myCar, sizeof(Car), 1, fout);
如果您有一个指向结构的指针数组,也会发生同样的情况:
Car* cars[];
fwrite(cars[i], sizeof(Car), 1, fout);
由于 cars[i]
已经具有 fwrite
所需的地址,因此不需要任何运算符。
需要注意的一件事是 C 编译器填充结构 - 它们可能会在字段之间插入未使用的字节,以确保每个字段从边界开始(取决于您的系统字对齐,通常为 4)。
因此,这 15 个 char
数组可能会附加一个额外的字节来四舍五入到 16。
如果将整个结构写入文件,这些字节也将被写入。
这就是为什么通常建议单独编写每个字段,但如果这只是一个练习,可能并不重要。
关于c - Fwrite 通过引用传递的动态结构,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53471806/