Gre*_*ill 186
C没有提供语言功能 - 您必须自己完成并按成员比较每个结构成员.
Suf*_*ian 106
您可能很想使用memcmp(&a, &b, sizeof(struct foo))它,但它可能无法在所有情况下使用.编译器可以将对齐缓冲区空间添加到结构,并且在位于缓冲区空间中的存储器位置处找到的值不保证是任何特定值.
但是,如果在使用它们之前使用calloc或者使用memset结构的完整大小,则可以进行浅层比较memcmp(如果结构包含指针,则仅当指针指向的地址相同时才匹配).
Ben*_*Ben 22
如果你做了很多我建议写一个比较两个结构的函数.这样,如果你改变了结构,你只需要在一个地方改变比较.
至于怎么做....你需要单独比较每个元素
小智 18
由于结构中字段之间存在潜在的随机填充字符,因此无法使用memcmp来比较结构的相等性.
// bad
memcmp(&struct1, &struct2, sizeof(struct1));
Run Code Online (Sandbox Code Playgroud)
对于像这样的结构,上面会失败:
typedef struct Foo {
char a;
/* padding */
double d;
/* padding */
char e;
/* padding */
int f;
} Foo ;
Run Code Online (Sandbox Code Playgroud)
您必须使用成员比较才能安全.
@Greg是正确的,在一般情况下必须编写显式比较函数.
可以使用memcmpif:
NaN.-Wpadded与clang一起使用来检查)或者memset在初始化时显式初始化结构.BOOL)具有不同但等效的值.除非您正在为嵌入式系统编程(或编写可能在其上使用的库),否则我不会担心C标准中的一些极端情况.在任何32位或64位设备上都不存在近与远指针的区别.我所知道的非嵌入式系统没有多个NULL指针.
另一种选择是自动生成相等函数.如果以简单的方式放置结构定义,则可以使用简单的文本处理来处理简单的结构定义.您可以将libclang用于一般情况 - 因为它使用与Clang相同的前端,它可以正确处理所有角落情况(禁止错误).
我还没有看到这样的代码生成库.但是,它看起来相对简单.
但是,这种生成的相等函数通常也会在应用程序级别执行错误操作.例如,UNICODE_STRINGWindows中的两个结构应该浅或深吗?