是否有一个工具可以在C#应用程序中查找未引用的函数(死的,过时的代码)?

如果没有从任何地方调用foo(),我想删除foo()。

Gendarme将检测没有上游呼叫者的私有方法。 它是跨平台的,最新版本处理“ AvoidUncalledPrivateCodeRule ”。

FxCop将检测没有上游调用者的公共/受保护方法。 但是,如果没有上游调用者,FxCop不会检测所有方法,因为它是为了检查您的代码是否是库的一部分,因此公共成员被排除在外。 您可以使用NDepend搜索没有上游调用者的公共成员,我在此处详细介绍了其他StackOverflow答案 。

(编辑:添加了关于Gendarme的信息,实际上提出了提问者的要求)

NDepend还将报告可能未使用的代码。

请记住,如果方法被标记为public ,Resharper(以及可能还有其他类似工具)将不会突出显示未使用的方法。 静态代码分析工具无法检查解决方案之外的其他程序集是否使用了程序集的方法。 因此,清除未使用方法的第一步是降低其对privateinternal的可见性。

是的, MZ-Tools插件具有审查死代码function。

Resharper这样做,而不仅仅是方法。 它也使用using语句,变量等。

NDepend工具可以帮助在.NET代码库中查找未使用的代码。 免责声明:我是这个工具的开发人员之一。

NDepend建议在LINQ查询(CQLinq)上编写代码规则 。 提出了大约200个默认代码规则 ,其中3个专用于未使用/死代码检测:

  • 可能死的类型 (因此检测未使用的类,结构,接口,委托…)
  • 可能死的方法
  • 可能死的菲尔兹

NDepend集成在Visual Studio中,因此可以在IDE内部检查/浏览/编辑这些规则。 该工具还可以集成到您的CI流程中,它可以构建报告 ,显示违反规则和罪魁祸首的代码元素。

如果单击这些规则的源代码的这三个链接,您将看到有关类型和方法的链接有点复杂。 这是因为它们不仅检测未使用的类型和方法,还检测由未使用的死类型和方法(递归)使用的类型和方法。

这是静态分析 ,因此在规则名称中可能是潜在的前缀。 如果通过reflection使用代码元素,则这些规则可能会将其视为未使用,而不是这种情况。

除了使用这3条规则外,我还建议通过测试来测量代码覆盖率并努力实现全面覆盖。 通常,您会看到测试无法覆盖的代码实际上是未使用/死代码,可以安全地丢弃。 这在复杂算法中尤其有用,因为不清楚代码分支是否可达。

好吧,如果VS本身不这样做,一个简单的方法是右键单击该方法并选择“查找所有引用”。 如果只有一个引用(声明它的位置),则很可能不会在其他任何地方使用它。