c# – 使用LINQ时避免代码重复

c# – 使用LINQ时避免代码重复,第1张

概述好的,我有很多方法,如下所示: – 按艺术家,专辑,年份等对列表进行排序. public void SortByAlbum(SortOrder sortOrder) { if (sortOrder == SortOrder.Ascending) _list = _list.OrderBy(x => x.Album).ToList() 好的,我有很多方法,如下所示: – 按艺术家,专辑,年份等对列表进行排序.
public voID SortByAlbum(SortOrder sortOrder)        {           if (sortOrder == SortOrder.Ascending)              _List = _List.OrderBy(x => x.Album).ToList();           else if (sortOrder == SortOrder.Descending)              _List = _List.OrderByDescending(x => x.Album).ToList();        }

还有这个:

public voID SortByArtist(SortOrder sortOrder)        {           if (sortOrder == SortOrder.Ascending)              _List = _List.OrderBy(x => x.Artist).ToList();           else if (sortOrder == SortOrder.Descending)              _List = _List.OrderByDescending(x => x.Artist).ToList();        }

现在显然这不是好代码所以它需要重构为一个Sort()方法,但我不知道如何以最简单的方式做到这一点.我不在乎它是否使用IComparer或liNQ.

我希望它看起来像这样:

public voID Sort(SortOrder sortOrder,SortType sortType)    {        //implementation here    }    public enum SortType    {       Artist,Album,Year    }

那么最简洁的方法是什么,没有代码重复

谢谢,李

解决方法 您应该能够模仿OrderBy扩展方法的签名:

更新1您必须在keySelector Func的第一个通用参数中显式.我打算猜你的类型并称之为“歌曲”.

public voID Sort<TKey>(SortOrder sortOrder,Func<Song,TKey> keySelector){    if (sortOrder == SortOrder.Descending)    {        _List = _List.OrderByDescending(keySelector).ToList();     }    else    {        _List = _List.OrderBy(keySelector).ToList();     }}

现在您可以像这样调用“排序”:

Sort(SortOrder.Descending,x => x.Album);

更新2

跟进Tom Lokhorst的评论:如果你想预定义一些速记排序标准,你可以通过定义这样一个类来实现:

public static class SortColumn{    public static Readonly Func<Song,string> Artist = x => x.Artist;    public static Readonly Func<Song,string> Album = x => x.Album;}

现在你可以简单地打电话:

Sort(SortOrder.Descending,SortColumn.Artist);
总结

以上是内存溢出为你收集整理的c# – 使用LINQ时避免代码重复全部内容,希望文章能够帮你解决c# – 使用LINQ时避免代码重复所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/langs/1237162.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2022-06-06
下一篇2022-06-06

发表评论

登录后才能评论

评论列表(0条)

    保存