草庐IT

icomparer

全部标签

C# - 如何为 IComparable<T> 类实现多个比较器?

我有一个实现IComparable的类。publicclassMyClass:IComparable{publicintCompareTo(MyClassc){returnthis.whatever.CompareTo(c.whatever);}etc..}然后我可以调用类的泛型列表的排序方法Listc=newList();//Addstuff,etc.c.Sort();并根据我的比较器对列表进行排序。如何根据MyClass的其他属性指定更多比较器以不同方式对我的集合进行排序,以便让用户以多种不同方式对我的集合进行排序? 最佳答案

c# - IComparable 魔法 - 为什么它是有效的陈述?

我不明白为什么它会起作用......classProgram{staticvoidMain(string[]args){IComparable.Equals(12,3);}}IL代码:.methodprivatehidebysigstaticvoidMain(string[]args)cilmanaged{.entrypoint//Codesize21(0x15).maxstack8IL_0000:nopIL_0001:ldc.i4.s12IL_0003:box[mscorlib]System.Int32IL_0008:ldc.i4.3IL_0009:box[mscorlib]Syst

c# - 我们应该扩展 Comparer<T> 还是实现 IComparer<T>

在编写比较器类时,从4.0版开始的C#中的最佳实践是什么:一个。我们应该继承Comparer抽象类吗?或我们是否应该实现IComparer接口(interface)。有什么优点和缺点? 最佳答案 我建议您扩展Comparer类而不是实现IComparer界面,与Microsoft一样(参见下面的第一个引用资料)。现在,如果您希望您的对象本身(无论T是什么)能够与自身进行比较,它可以实现IComparable接口(interface)(参见下面的第二个引用)。发件人:http://msdn.microsoft.com/en-us/li

c# - 为什么 List<>.OrderBy LINQ 在 Debug模式下比 IComparable+List<>.Sort 更快?

我感兴趣的是使用LINQ或通过实现IComparable接口(interface)和List.Sort对我的类进行排序是否会更快。当LINQ代码更快时,我感到非常惊讶。为了进行测试,我使用不太恰当的名称TestSort创建了一个非常简单的类,实现了IComparable。classTestSort:IComparable{privateintage;privatestringgivenName;publicintAge{get{returnage;}set{age=value;}}publicstringGivenName{get{returngivenName;}set{givenN

c# - 使用自定义 IComparer 对 CollectionViewSource 进行排序

我正在尝试对派生自CollectionViewSource的集合进行排序,该集合仅具有用于排序的SortDescriptions。不幸的是,我需要能够使用我自己的自定义IComparer,但我似乎无法找到一种方法来做到这一点。想想数据网格,我有自己的多列排序算法。我在想一种方法是使用实​​现CollectionChanged的​​集合,它是CollectionViewSource和我的真实数据源之间的附加层,但如果有人有任何建议,我真的更喜欢更好的方法。 最佳答案 BeaStollnitz有一个自定义排序示例here.那篇文章的重点

C# lambda 表达式和 IComparer

我在C#中使用lambda表达式对数组进行排序和搜索。我不想在我的类中实现IComparer接口(interface),因为我需要对多个成员字段进行排序和搜索。classWidget{publicintfoo;publicvoidBar(){Widget[]widgets;Array.Sort(widgets,(a,b)=>a.foo.CompareTo(b.foo));Widgetx=newWidget();x.foo=5;intindex=Array.BinarySearch(widgets,x,(a,b)=>a.foo.CompareTo(b.foo));}}虽然排序工作正常,但

c# - 如何使用 IComparable 接口(interface)?

我需要一个基本示例来说明如何使用IComparable接口(interface),以便我可以按升序或降序以及我正在排序的对象类型的不同字段进行排序。 最佳答案 好吧,因为你正在使用List只使用Comparison会简单得多,例如:Listdata=...//sortbynamedescendingdata.Sort((x,y)=>-x.Name.CompareTo(y.Name));当然,对于LINQ,您可以只使用:varordered=data.OrderByDescending(x=>x.Name);但是你可以在List中重新

java 8 - Icomparable<T> 的注释 compareTo <T> 也添加了注释 compareTo(Object o)

我有注释packagejavaannotationtest;importjava.lang.annotation.*;@Target({ElementType.METHOD})@Retention(RetentionPolicy.RUNTIME)public@interfaceCustomAnnotation{}这适用于以下类中的compareTopackagejavaannotationtest;publicclassCustomerimplementsComparable{@Override@CustomAnnotationpublicintcompareTo(Customero)

c# - 构造函数中的 SortedSet<T> 和匿名 IComparer<T> 不起作用

为什么匿名函数可以作为方法的参数,而不是构造函数的参数?如果我创建一个List,它有一个带有以下签名的排序方法:publicvoidSort(IComparercomparer)以下工作的地方:Listlist=newList();list.Sort((a,b)=>a.CompareTo(b));SortedSet有一个具有类似签名的构造函数:publicSortedSet(IComparercomparer)但是在构造函数中使用匿名函数时会失败。以下内容无效:SortedSetset=newSortedSet((a,b)=>a.CompareTo(b));创建排序类按预期正常工作:p

c# - 构造函数中的 SortedSet<T> 和匿名 IComparer<T> 不起作用

为什么匿名函数可以作为方法的参数,而不是构造函数的参数?如果我创建一个List,它有一个带有以下签名的排序方法:publicvoidSort(IComparercomparer)以下工作的地方:Listlist=newList();list.Sort((a,b)=>a.CompareTo(b));SortedSet有一个具有类似签名的构造函数:publicSortedSet(IComparercomparer)但是在构造函数中使用匿名函数时会失败。以下内容无效:SortedSetset=newSortedSet((a,b)=>a.CompareTo(b));创建排序类按预期正常工作:p