c#中ValueType的泛型约束

本文关键字:泛型 约束 ValueType | 更新日期: 2023-09-27 17:49:51

我有一个限制参数使用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;}
}

c#中ValueType的泛型约束

不使用==运算符,您可以始终使用静态object.Equals(object, object)方法。

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

所以,你的方法可以这样写:
public virtual bool MyMethod(T entity1, T entity2)
{
    return object.Equals(entity1.EntityId, entity2.EntityId);
}

您不需要额外的约束,事实上,如果T是引用类型,它甚至在某种程度上仍然可以工作。

您可以在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);
    }
}