C#中ValueType的泛型类型约束

时间:2015-05-20 11:37:38

标签: c# .net generics where

我有通用类限制参数使用intlong类型。我的问题是我需要在我的方法中比较这个参数类型的变量。但是编译器说我无法比较这些项目 -

  

运算符'=='无法应用于'K'和'K'类型的操作数

我的代码:

public class MyClass<T,K>
    where T : Entity<K>
    //where K : ??? - what can I do?
{
    public virtual bool MyMethod(T entity1, T entity2)
    {
        return entity1.EntityId == entity2.EntityId;//Operator '==' cannot be applied to operands of type 'K' and 'K'
    }
}
public abstract class Entity<T>
{
    public T EntityId{get;set;}
}

2 个答案:

答案 0 :(得分:7)

您可以随时使用静态object.Equals(object, object) method,而不是使用==运算符。

该对象将调用 - 可能被覆盖 - 传递给它的任何内容Equals method,对于值类型,应该实现它以支持值相等。

所以,你的方法可以写成:

public virtual bool MyMethod(T entity1, T entity2)
{
    return object.Equals(entity1.EntityId, entity2.EntityId);
}

您不需要额外的约束,事实上,如果T是引用类型,它甚至会以某种方式工作。

答案 1 :(得分:4)

您可以在IEquatable<K>上约束K并使用Equals

public class MyClass<T,K>
    where T : Entity<K>
    where K : IEquatable<K>
{
    public virtual bool MyMethod(T entity1, T entity2)
    {
        return entity1.EntityId.Equals(entity2.EntityId);
    }
}