List.IndexOf() 与 List.FindIndex() 的效率

2024-02-25

采用哪一种方法

  • List<T>.IndexOf() and
  • List<T>.FindIndex()

就处理时间而言是否更高效?

的类型T在这种情况下是String.


IndexOf执行 for 循环,使用Equals实现正在搜索的对象以查找匹配项。FindIndex还执行 for 循环但评估Predicate检查是否匹配。

它们都归结为一个 for 循环。虽然他们在技术上都有O(n)设计中,委托的使用FindIndex会有一些开销。性能差异可以看出Denis19901 的回答 https://stackoverflow.com/a/67823322/74757。以下是一些 MSDN 摘录:

List<T>.IndexOf Method (T) https://msdn.microsoft.com/en-us/library/e4w08k17%28v=vs.110%29.aspx:

该方法执行线性搜索;因此,该方法是一个 O(n)操作,其中n is Count.

List<T>.FindIndex Method (Predicate<T>) https://msdn.microsoft.com/en-us/library/x1xzf2ca%28v=vs.110%29.aspx:

该方法执行线性搜索;因此,该方法是一个 O(n)操作,其中n is Count.

也就是说,这两个函数的使用方式会有很大不同。前者假设您有列表中的一个对象,您只需要知道它在列表中存在的索引(如果有)。

后者假设您知道有关对象的一些条件,并且您希望找到列表中对象与该条件匹配的第一个索引。可能有多个匹配项,但该方法返回第一个匹配项。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

List.IndexOf() 与 List.FindIndex() 的效率 的相关文章

随机推荐

  • 共享常量池?

    与 Java 虚拟机相比 Dalvik 虚拟机获得 共享常量池 意味着什么 这是什么好处 Dalvik 机器如何实现这一点 Java 虚拟机将每个类存储在单独的 class 文件中 每个类文件都有一个常量池 用于存储字符串 方法名称 类名称
  • @staticmethod 在 CPython 或 Micropython 中保存任何内存吗?

    在回答最近的问题时 我重复了我的假设 即使用的一个原因 staticmethod是为了节省内存 因为静态方法只被实例化一次 这个断言可以在网上很容易找到 例如here https newbedev com what is the advan
  • 无法启动mongos

    我正在尝试设置简单的分片 在没有任何副本集的单个主机上 但是我无法继续下去 因为当我尝试启动 mongos 时会发生这种情况 C gt mongos configdb localhost 27010 port 27011 I get Bad
  • android:使用ActivityGroup嵌入活动

    我正处于构建应用程序的概念化 设计阶段 但遇到了一些障碍 本质上 我正在寻找一种将一个活动嵌入到另一个活动的 UI 中的方法 类似于 TabHost TabActivity 的方式 屏幕顶部将有一个窗口 其中包含其他活动 其下方将是独立于上
  • 如何在Azure中托管的React应用程序中使用环境变量

    我对 React 还很陌生 并且总体上也在探索 Azure 我有 ERP 背景 但该背景确实包括使用 VSTS 和 CI CD 等工具 我非常依赖使用 VSTS 中的 库 来指定每个环境的变量 然后在部署时指定这些变量 但 我一直在互联网上
  • Bash 变量格式

    关于使用 BASH 编写脚本 以下变量之间有什么区别 var var var var 之间没有区别 var and var 之间没有区别 var and var 但在某些情况下 当您使用以前的版本时 解析器可能无法识别您的意图 考虑 foo
  • xpath:有没有办法获取xpath中所有孩子的文本

    我在 Firefox 上使用 xpath 引擎 我有html span b prefix one b not bold part span span prefix two not bold part span 我想要所有的span具有以 前
  • Excel 滚动条不允许屏幕更新,除非您“放下”滚动条

    希望这很简单 但经过一个小时的在线搜索后 我找不到其他人抱怨这个问题 也许我只是还没有找到合适的措辞来描述它 我的公司最近切换到 Excel 2016 我讨厌滚动条的工作方式 如果您用鼠标拖动滚动条 当前视图将冻结在适当的位置 直到您 放下
  • 根据使用 python 的字符串经验转换为年数[关闭]

    Closed 这个问题需要细节或清晰度 help closed questions 目前不接受答案 我有一列数据如下 9年3个月22天 如何将其转换为 9 3 12 22 365 9 31 我想要输出为 9 31 如何在 python 中做
  • .NET 中的 PHP htmlspecialcharacters 等效吗?

    PHP 有一个很棒的函数 叫做html 特殊字符 https www php net manual en function htmlspecialchars php当你向它传递一个字符串时 它会用它们的安全等价物替换所有 HTML 特殊字符
  • 将 WiX UI 迁移到 Burn

    我有一个可用的 WiX 安装程序 带有使用 WixUI Mondo MyApp wxs 文件的自定义 UI 我必须扩展我的安装程序才能运行另一个 exe 安装程序 我知道 Burn 是实现此目的的方法 我创建了一个 Burn 项目 将我的原
  • jquery移动页面闪烁

    页面加载后和执行 listview refresh 时页面闪烁 所以在转换之后会出现闪烁 friendsList append data listview refresh 我得到了闪烁 尝试添加 EDIT 刷新列表视图时 我理解列表视图内的
  • 为什么从 AngularJS 控制器内部加载时 google graph 不起作用。浏览器变白,控制台中没有任何错误

    这样 当我像在页面加载期间一样加载它时 我的直方图就可以正常工作 document ready x new Array 10 for var i 0 i lt 10 i x i new Array 2 x i 0 txt x i 1 100
  • WordPress:如何通过自定义分类在作者页面中显示帖子计数

    我正在尝试使用计数器在作者页面中显示自定义分类 但似乎我不知道该怎么做 我有一个代码函数 php add action pre get posts function q if is admin q gt is main query q gt
  • Sitecore + Lucene 搜索 FieldQuery 带空字符串

    我正在使用 FieldQuery 对象创建 Sitecore Ecommerce Search Query 然后 我使用 LuceneQueryBuilder 类将 Sitecore 查询转换为 Lucene Net Search Quer
  • django excel xlwt

    在 django 网站上 我想根据数据库中的一些数据生成一个 excel 文件 我正在考虑使用xlwt http pypi python org pypi xlwt 但它只有一个将数据保存到文件的方法 如何获取文件到 HttpRespons
  • 在 VBA 中填充一行

    我试图找出如何填充 或复制 一行 lastUsedRow 直到最后一行 然而 我发现自己在指定范围方面遇到了困难 特别是因为我正在处理具有不同大小的不同数据集 Before 我需要找出lastUsedRow lastUsedRow Rang
  • 从哪里获取这个丢失的文件 - Android Studio、模拟器

    升级我的 android studio 后 我尝试创建一个模拟器 但在尝试启动 AVD 时出现此错误 Emulator statvfs home nompumelelo android avd Pixel 2 API 24 avd snap
  • 玩框架2 ebean @manytoone 列指定两次

    我遇到了 ebean 的一些问题 使用 play Framework 2 版本 2 2 1 我有两节课 我的图表类 public class Graph extends Model Id Column name id private Str
  • List.IndexOf() 与 List.FindIndex() 的效率

    采用哪一种方法 List