c# - 使用枚举上的 XOR 运算符重载 GetHashCode 和相等运算符

标签 c# operators xor gethashcode

我有以下类,它是静态分析包的一部分。

  • MetricKey 对象用作字典键。
  • DecisionMetricUnitPortfolio 都是枚举。

我必须重写相等运算符 (==) 才能使字典键匹配工作。我使用了 http://msdn.microsoft.com/en-us/library/ms173147.aspx 上的指导。该指南说我应该重载我已经完成的 GetHashCode 方法,但我不明白将枚举转换为整数以进行 XOR (^) 操作的含义。我所做的是否有效,或者由于我的枚举整数值重叠,我会得到冲突的哈希码吗?:

public class MetricKey
{
    public MetricKey(Decision decision, MetricUnit metricUnit, Portfolio portfolio)
    {
        Decision = decision;
        Unit = metricUnit;
        Portfolio = portfolio;
    }

    public Decision Decision { get; private set; }
    public MetricUnit Unit { get; private set; }
    public Portfolio Portfolio { get; private set; }

    public static bool operator == (MetricKey a, MetricKey b)
    {
        if (ReferenceEquals(a, b))
            return true;
        if (((object) a == null) || ((object) b == null))
            return false;
        return a.Decision == b.Decision && a.Unit == b.Unit && a.Portfolio == b.Portfolio;
    }

    public static bool operator != (MetricKey a, MetricKey b)
    {
        return !(a == b);
    }

    public override bool Equals(System.Object obj)
    {
        if (obj == null)
            return false;
        var metricKey = obj as MetricKey;
        if ((System.Object) metricKey == null)
            return false;
        return Decision == metricKey.Decision && Unit == metricKey.Unit && Portfolio == metricKey.Portfolio;
    }

    public bool Equals(MetricKey metricKey)
    {
        if ((object) metricKey == null)
            return false;
        return Decision == metricKey.Decision && Unit == metricKey.Unit && Portfolio == metricKey.Portfolio;
    }

    public override int GetHashCode()
    {
        return (int)Decision ^ (int)Unit ^ (int)Portfolio;
    }
}

最佳答案

转换为 int 没有任何问题 - 但是,我实际上会避免异或 - 很容易与枚举的可能值(1、2、3 等)产生冲突。请注意,碰撞不会破坏任何东西,但它们会使事情变得更加昂贵。我可能会使用类似的东西(随机选择,从 C# 编译器对匿名类型的处理中获取灵感):

int num = -1962473570;
num = (-1521134295 * num) + (int)Decision;
num = (-1521134295 * num) + (int)Unit;
return (-1521134295 * num) + (int)Portfolio;

关于c# - 使用枚举上的 XOR 运算符重载 GetHashCode 和相等运算符,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2320808/

相关文章:

ruby - Ruby 是否有 nil 值的安全导航运算符的语法,就像在 Groovy 中一样?

java - 程序在数组中查找与给定值异或的对

C# 如何在对象构造后执行代码(postconstruction)

javascript - mvc 5 中图像未成功上传

c# - 具有动态列数的平面文件规范化

c# - 为什么我不能在 lock 语句的主体中使用 'await' 运算符?

java - 最少的代码,缩短表达

java - "x = x++"之后的 x 是什么?

c# - 大量数据的最佳加密(速度至关重要)?

c - 异或链表交换2个节点C