C 编码::将结构写入内存块

标签 c heap-memory memcpy

我正在开发一个必须用标准 C 编码的项目。(不是 C++。)不久前,我编写了以下程序,将不同结构的内容写入二进制文件:

#include <stdio.h>
#include <stdlib.h>
    
typedef struct structA{
        int a, b, c;
}AAA;
typedef struct structB{
        int a, b, c, d, e;
}BBB;
    
int main( int argc, char **argv ){

        // Create and open the output file
        FILE *fd = fopen("test.txt", "w");

        AAA* a1 = (AAA*)malloc( sizeof(AAA) );
        AAA* a2 = (AAA*)malloc( sizeof(AAA) );
        BBB* b1 = (BBB*)malloc( sizeof(BBB) );

        a1->a = 1;   a1->b = 2;   a1->c = 3;
        a2->a = 4;   a2->b = 5;   a2->c = 6;
        b1->a = 10;  b1->b = 20;  b1->c = 30;  b1->d = 40;  b1->e = 50;

        // Write all these structs to the file:
        fwrite((char*)&a1, sizeof(AAA), 1, fd);
        fwrite((char*)&a2, sizeof(AAA), 1, fd);
        fwrite((char*)&b1, sizeof(BBB), 1, fd);

        // Close the file
        fclose( fd );

        free( a1 );
        free( a2 );
        free( b1 );

        printf("END OF PROGRAM.\n");
        return 0;
}

上面的代码运行得很好......尽管我无法通过查看输出来判断:

me@ubuntu:/home/me# more test.txt
▒$▒&V
me@ubuntu:/home/me#

我有另一个程序可以读取该文件并从结构中提取所有信息。所以我知道上面的代码正是我想要的。

但是现在,我需要将这些结构写入分配的内存块,而不是写入文件。我以为这很容易:

#include <stdio.h>
#include <stdlib.h>
    
typedef struct structA{
        int a, b, c;
}AAA;
typedef struct structB{
        int a, b, c, d, e;
}BBB;
    
int main( int argc, char **argv ){

        u_char* BlockOfMemory = (u_char*) malloc( sizeof(u_char) * 100 );

        AAA* a1 = (AAA*)malloc( sizeof(AAA) );
        AAA* a2 = (AAA*)malloc( sizeof(AAA) );
        BBB* b1 = (BBB*)malloc( sizeof(BBB) );

        a1->a = 1;   a1->b = 2;   a1->c = 3;
        a2->a = 4;   a2->b = 5;   a2->c = 6;
        b1->a = 10;  b1->b = 20;  b1->c = 30;  b1->d = 40;  b1->e = 50;

        // Write all these structs into BlockOfMemory:
        memcpy ( BlockOfMemory, &a1, sizeof( AAA ) );
        memcpy ( (BlockOfMemory+sizeof(AAA)), &a2, sizeof( AAA ) );
        memcpy ( (BlockOfMemory+sizeof(AAA)+sizeof(AAA)), &b1, sizeof( BBB ) );

        printf("==>  %hhn\n", BlockOfMemory);

        free( a1 );
        free( a2 );
        free( b1 );
        free( BlockOfMemory );

        printf("END OF PROGRAM.\n");
        return 0;
}

有效果吗?我不知道:

me@ubuntu:/home/me# gcc -Wall writeBlock.c
me@ubuntu:/home/me# ./a.out
==>
END OF PROGRAM.
me@ubuntu:/home/me#

这里的目标是内存块必须包含与二进制文件完全相同的信息。我处于一种奇怪的情况,我的代码编译并运行,但考虑到我拥有的工具(VI 和 GCC),我无法验证我的代码是否正确或偏离目标。

有人可以建议吗?另外,memcpy() 会是这里使用的函数吗?谢谢。

编辑:修复了当我错误地添加第二个“free( b1 );”时的第一个程序由于剪切粘贴错误。

最佳答案

正如已经指出的,您将指针 a1 的地址传递给 memcpy,对于 a2b1 也是如此。应该是

memcpy ( BlockOfMemory, a1, sizeof( AAA ) );
memcpy ( (BlockOfMemory+sizeof(AAA)), a2, sizeof( AAA ) );
memcpy ( (BlockOfMemory+sizeof(AAA)+sizeof(AAA)), b1, sizeof( BBB ) );

如果你想打印BlockOfMemory的内容,你需要转换回AAA*BBB*并用指针算术移动,像这样

unsigned char* tmp = BlockOfMemory;
AAA* x = (AAA*)tmp;
printf("==>  %d %d %d\n", x->a, x->b, x->c);

tmp += sizeof(AAA);
x = (AAA*)tmp;
printf("==>  %d %d %d\n", x->a, x->b, x->c);

tmp += sizeof(AAA);
BBB* y = (BBB*)tmp;
printf("==>  %d %d %d %d %d\n", y->a, y->b, y->c, y->d, y->e);

关于C 编码::将结构写入内存块,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/63563840/

相关文章:

c - memcpy 的疑问。需要澄清

根据 C 中的字节数从 char 数组复制整数

c - memcpy 上的段错误

c - 将长值从 fork 进程传递给其父进程

c - 返回具有多个值的两个变量

c++ - 无法删除 unsigned char* 数组

java - 使用编译器 API 的程序中的内存泄漏

c++ - 在 C/C++ 中读取和写入二进制文件的中间部分

c - 如何使用 fscanf 读取带有分隔符的文件?

c++ - 使用 unique_ptr 制作的堆元素是否移动到堆栈上仍然分配在堆上?