memcmp比较结构体

本文探讨了使用memcmp函数比较结构体的潜在问题,特别是在结构体包含未初始化成员时。通过实例对比了初始化与未初始化结构体成员的影响,指出memcmp可能给出错误的比较结果。建议在C语言中自定义比较函数,而在C++中重载等于操作符。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

memcmp比较结构体


在日常编码中,当一个结构体内不含有指针成员时,有时为了方便,我们会使用memcmp来对两个结构体进行比较,但是这种做法不是一个正确的方法,也可能会导致错误的比较结果,我们以下面的例子来进行验证。

例子1:

#include <iostream>

struct Info
{
	char a;
	int b;
};

int main()
{
	Info i1, i2;
	i1.a = i2.a = 'a';
	i1.b = i2.b = 1;

	for (int i = 0; i < sizeof(Info); i++)
	{
		printf("%x ", ((unsigned char *)&i1)[i]);
	}

	std::cout << std::endl;

	for (int i = 0; i < sizeof(Info); i++)
	{
		printf("%x ", ((unsigned char *)&i2)[i]);
	}

	std::cout << std::endl;

	int nRet = memcmp(&i1, &i2, sizeof(Info));
	printf("memcmp = %d\n", nRet);

	getchar();
	return 0;
}

两个结构体,没有做任何初始化操作,分别赋相同的值,打印出结构体每一个字节的值,并调用memcmp进行比较,输出结果:
在这里插入图片描述
此时这两个结构体是相同的,对结构体的每一位我们进行分析:在x86下该结构体总共有8个字节,为了字节对齐,char a占1个字节,后面会补齐3位,但是由于这三位没有初始化也不会赋值,所以它们的值是cc,后面的4个字节是int占据的。

例子2:

我们在例子1的基础上,在给i1赋值前先用memset将i1结构体清零(其他代码不变):

Info i1, i2;
	memset(&i1, 0, sizeof(Info));
	i1.a = i2.a = 'a';
	i1.b = i2.b = 1;

输出结果:
在这里插入图片描述
这个时候就算两个结构体每个成员变量值都相同,但是通过memcmp得出的结果却是不相同的,因为对i1调用了memset进行了清零,那么char a后面补齐的三个字节也会被清0,i2没有清零,导致两个结构体每一个字节内容不完全相等。
当我们使用memcmp比较两个结构体时,又不能保证对每个结构体都使用了memset进行清零操作,此时就会出现错误的结果。为了安全起见,在c语言中,可以自己写结构体比较函数;在c++中,结构体基本等同于类,重载=操作符,自己实现比较逻辑即可。
当然,对于全局的结构体,以及静态变量,编译器会将结构体占用的内存初始化为0,等同于memset

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Simple Simple

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值