【问题标题】:How to check if a generic has an operator? C#如何检查泛型是否有运算符? C#
【发布时间】:2014-06-17 17:59:30
【问题描述】:

我想为泛型类重载运算符 +(f,s)。如果 f 和 s 有加号运算符,它应该返回 +(f,s),否则返回 null。我该怎么做?

public class param<T> : TDefault 
{
    public string param_name;
    public T cnt;
    public param(T _cnt)
    {
        cnt=_cnt;
    }
    public static param<T> operator +(param<T> f, param<T> s)
    {
        if(T ? has_operator("+"))
            return param<T>(((f.cnt as ?)+(s.cnt as ?)) as T);
        return null;
    }
}

为了检查操作符的存在,我试过了

public static bool has_method(this object target,string method_name)
{
    return target.GetType().GetMethod(method_name)!=null;
}

但是

int x;
print (x.has_method("+="));

打印“假”

【问题讨论】:

标签: c# generics


【解决方案1】:

试试这个:

public class Param<T>
{
    private static readonly Func<T, T, T> addMethod;
    static Param()
    {
        try
        {
            ParameterExpression left = Expression.Parameter(typeof (T), "left");
            ParameterExpression right = Expression.Parameter(typeof (T), "right");
            addMethod = Expression.Lambda<Func<T, T, T>>(Expression.Add(left, right), left, right).Compile();
        }
        catch (InvalidOperationException)
        {
            //Eat the exception, no + operator defined :(
        }
    }

    public string param_name;
    public T cnt;
    public Param(T _cnt)
    {
        cnt = _cnt;
    }

    public static Param<T> operator +(Param<T> leftOperand, Param<T> rightOperand)
    {
        if (addMethod != null)
        {
            return new Param<T>(addMethod(leftOperand.cnt, rightOperand.cnt));
        }
        return null;
    }
}

private static void Main(string[] args)
{
    var pi = new Param<int>(5);
    var pi2 = new Param<int>(6);
    var pi3 = pi + pi2;

    var pi4 = new Param<ooject>(5);//Wont work
    var pi5 = new Param<object>(6);
    var pi6 = pi4 + pi5;
}

Credit goes to JonSkeet and Marc

【讨论】:

    猜你喜欢
    • 2022-11-04
    • 2011-08-19
    • 2013-07-22
    • 2020-04-25
    • 1970-01-01
    • 2020-04-06
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多