热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

.NETC#中的List扩展方法

本文介绍了一个实用的工具类`ListExtensions`,提供了多种针对`List`的扩展方法,包括无序和有序列表中的对象检索及计数功能。
在 .NET C# 开发中,对列表(`List`)的操作是非常常见的需求。为了简化这些操作,我们创建了一个名为 `ListExtensions` 的静态类,提供了一系列扩展方法来增强 `List` 的功能。

```csharp
public static class ListExtensions
{
///
/// 在无序或有序的 List 中查找所有与指定值匹配的对象。
///

public static IEnumerable FindAll(this List list, T searchValue)
{
return list.Where(item => item.Equals(searchValue));
}

///
/// 计算无序或有序的 List 中与指定值匹配的对象数量。
///

public static int CountMatches(this List list, T searchValue)
{
return list.FindAll(searchValue).Count();
}

///
/// 在有序的 List 中查找所有与指定值匹配的对象。此方法要求列表已排序,否则结果可能不正确。
///

public static T[] BinarySearchFindAll(this List list, T searchValue) where T : IComparable
{
var results = new List();
int index = list.BinarySearch(searchValue);
if (index >= 0)
{
results.Add(list[index]);
// 向左搜索
for (int i = index - 1; i >= 0 && list[i].CompareTo(searchValue) == 0; i--)
{
results.Add(list[i]);
}
// 向右搜索
for (int i = index + 1; i {
results.Add(list[i]);
}
}
return results.ToArray();
}

///
/// 计算有序的 List 中与指定值匹配的对象数量。此方法要求列表已排序,否则结果可能不正确。
///

public static int BinarySearchCountMatches(this List list, T searchValue) where T : IComparable
{
return list.BinarySearchFindAll(searchValue).Length;
}
}
```

以上代码展示了如何通过扩展方法来增强 `List` 类的功能,使得开发者能够更方便地进行列表数据的查询和统计。特别是对于已经排序的列表,使用二分查找方法可以显著提高性能。
推荐阅读
author-avatar
merlion-p
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有