c# – 与其他参数一起传递操作符

前端之家收集整理的这篇文章主要介绍了c# – 与其他参数一起传递操作符前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我有一些非常低效的代码,其中许多行显示4次,因为我通过排列与“<”和“>”操作和各种变量和常量.似乎有一种方法来编写函数一次,并且随着必须改变的值和“ref”变量传递到运算符中.我要学什么技术?已经建议“代表”,但我看不到如何以这种方式使用它们.这是在C#2.0,VS2005,但如果该技术是通用的,也可以与C一起使用,那将是巨大的.

请求一些代码:以下出现在许多guises,不同的“<”和“>”标志以及“ – ”符号混合:

if (move[check].Ypos - move[check].height / 200.0D < LayoutManager.VISIO_HEIGHT - lcac_c.top)
{
  move[check].Ypos = move[check].Ypos + adjust;
.
.
.

解决方法

在C中,使用 std::lessstd::greater函子.这两种方法都继承了 std::binary_function,所以你的泛型函数应该接受这种类型的实例.

在.NET中,相当于std :: binary_function是Func<T,U,R>.没有std :: less和std :: greater的等价物,但创建它们是相当微不足道的.请参见以下示例.

static class Functor
{
    static Func<T,T,bool> Greater<T>()
        where T : IComparable<T>
    {
        return delegate(T lhs,T rhs) { return lhs.CompareTo(rhs) > 0; };
    }

    static Func<T,bool> Less<T>()
        where T : IComparable<T>
    {
        return delegate(T lhs,T rhs) { return lhs.CompareTo(rhs) < 0; };
    }
}

注意,上述代码使用Func& .NET 3.5中的类.如果这是不可接受的,请考虑定义您自己的代理.

C调用示例:

void DoWork(const std::binary_function<int,int,bool>& myOperator,int arg1,int arg2)
{
    if (myOperator(arg1,arg2)) { /* perform rest of work */ }
}

void main()
{
    DoWork(std::less<int>(),100,200);
    DoWork(std::greater<int>(),200);
}

C#调用示例:

void DoWork(Func<int,bool> myOperator,arg2)) { /* perform rest of work */ }
}

void main()
{
    DoWork(Functor.Less<int>(),200);
    DoWork(Functor.Greater<int>(),200);
}

编辑:我修正了函子类的例子,或>运算符到通用类型不起作用(与C模板一样).

猜你在找的C#相关文章