c/c++结构体如何判断相等而且是否能相互赋值

本文探讨了C/C++中结构体的赋值与比较问题。详细解释了为何不能直接使用==运算符来比较结构体,并提供了一种通过重载==运算符来实现结构体比较的方法。同时,文章还讨论了字节对齐的影响及如何正确处理。

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

直接讲结论:

结构体之间,

  • 支持直接用等号=赋值
  • 但是不支持直接用==判断是否相等的,编译会报错。我们可以通过一个char指针指向两者的首地址,然后顺序判断每一个字节是否相同即可。但是逐个字节进行比较,而struct存在字节对齐,字节对齐时补的字节内容是随机的(尽管字节位置是一样的),会产生垃圾值,所以无法比较。方法就是自己写一个对比函数,逐个成员比较即可。可以看看这个博客 教你准确判断两个结构体是否相等_森明帮大于黑虎帮的博客-CSDN博客_判断结构体相等
//这个可以增多的,先写几个常用的(用得着的),但是为了大纲显示功能(还是显示全一点呗),这里还需要添加更多的属性
typedef struct Symbol 
{
/*
判断两个结构体是否相等:重载操作符"=="。
不能用函数memcpy来判断两个结构体是否相等:memcmp函数是逐个字节进行比较的,而struct存在字节对齐,
字节对齐时补的字节内容是随机的(虽然大家补齐的字节数都是一样的),会产生垃圾值,所以无法比较。
当然,对于全局的结构体,以及静态变量,编译器会将结构体占用的内存初始化为0,等同于memset,是可以直接判定相等的。
这也说明,结构体之间直接用等号相互赋值是没有问题的,因为有效数据总是位置正确的
*/
    bool operator == (Symbol &s) //把等于符号给重载了
    {
        return( (_type==s._type) && (name==s.name) && (path==s.path) && (line==s.line) && (signature==s.signature)
                && (typeref==s.typeref) && (kind==s.kind) && (scope==s.scope) && (roles==s.roles) && (end==s.end) );
    }
    
    QString _type;
    QString name;
    QString path;
    int line;
    QString signature;      //该符号如果是函数,那么signature就是它的形参列表
    QString typeref;        //该符号如果是函数,变量。该符号的类型 "typename:int", "typename:char"等
    QString kind;           //该符号是function、macro、prototype、variable、local等
    QString scope;          //如果是局部变量,该符号在哪个函数内
    QString roles;          //该符号是不是系统头文件,取值local,system
    int end;                //一个函数的截止行号
}Symbol;

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值