Maison >développement back-end >C++ >Comment trier correctement une liste à l'aide d'un IComparer personnalisé avec Linq OrderBy ?
Vous avez une liste générique
Il y a deux problèmes dans votre code :
Voici le comparateur personnalisé corrigé :
public class MyComparer : IComparer<Object> { public int Compare(Object stringA, Object stringB) { string[] valueA = stringA.ToString().Split('/'); string[] valueB = stringB.ToString().Split('/'); if (valueA.Length != 2 || valueB.Length != 2) { return String.Compare(stringA.ToString(), stringB.ToString()); } // Note: do error checking and consider i18n issues too :) if (valueA[0] == valueB[0]) { return int.Parse(valueA[1]).CompareTo(int.Parse(valueB[1])); } else { return int.Parse(valueA[0]).CompareTo(int.Parse(valueB[0])); } } }
Et ici est le code corrigé pour mettre à jour BindingList
case ListSortDirection.Ascending: MyComparer comparer = new MyComparer(); items = items.OrderByDescending(x => property.GetValue(x), comparer).ToList(); break; default: // Handle descending sort direction here break; } this.Items = items;
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!