Implementing custom IComparer<> (with example)

后端 未结 3 1162
小蘑菇
小蘑菇 2021-01-13 05:50

Ive just written the following code, which will order strings by their native string.Compare() but allow a collection of exceptions (in this case customPr

3条回答
  •  不思量自难忘°
    2021-01-13 06:01

    First, I think it's useful to restate the problem: You want to sort by:

    1. the index in the given array; if the item is not in the array, the index is infinity
    2. the string itself

    That means you can achieve your sort order by using OrderBy() for the first condition followed by ThenBy() for the second one:

    private static uint NegativeToMaxValue(int i)
    {
        if (i < 0)
            return uint.MaxValue;
        return (uint)i;
    }
    
    …
    
    var ordered = unorderered
        .OrderBy(a => NegativeToMaxValue(Array.IndexOf(new[] { "y", "x" }, a)))
        .ThenBy(a => a);
    

    NegativeToMaxValue() is necessary, because items not in the array should be last, but they would be first normally, because the index is -1. (A hackish and unreadable way to do the same would be to directly cast the result of IndexOf() to uint.)

    If you wanted to reuse this sorting by creating an IComparer, I believe there is nothing in .Net to help you with that. But you could use ComparerExtensions instead:

    IComparer comparer = KeyComparer
        .OrderBy(a => NegativeToMaxValue(Array.IndexOf(new[] { "y", "x" }, a)))
        .ThenBy(a => a);
    

提交回复
热议问题