ReSharper 2025.2 Help

代码检查:类型成员从未通过基类型访问(非私有可访问性)

此检查报告在解决方案中没有直接使用的接口成员,仅使用其派生类的实现。 它建议这样的成员可能不需要成为接口的一部分,在这种情况下,可以安全地将其移除以简化您的代码。

尽管这可能是您当前代码库中的一个问题,但检查无法考虑接口计划的未来使用情况。 因此,如果您计划通过接口使用报告的成员,您可以忽略此建议。

在下面的示例中, 名称 属性从未通过 IPage 接口使用;仅使用了其在 Post 类中的实现。 从 IPage 中移除 名称 将使您的代码更简洁,表明 名称Post 类的一部分。

public interface IPage { public string Name { get; set; } } public class Post : IPage { public string Name { get; set; } public Post(string name) => Name = name; public void PrintName() => Console.WriteLine(Name); } public class Test { public Test() { var post = new Post("New post"); post.PrintName(); } }

要使解决方案范围的检查生效,您需要启用以下至少一项:

  • 简化的全局使用检查:在 ReSharper 选项 Alt+R, O 代码检查 | 设置 页面上选择 当解决方案范围分析关闭时,显示未使用的非私有类型成员

  • 解决方案范围分析 :在 ReSharper 选项 的 代码检查 | 设置 页面上选择 启用解决方案级分析(_A) Alt+R, O

请注意,即使报告的成员在您的解决方案中没有直接使用,也可能存在间接使用的情况——例如,通过反射——或者它可能只是设计为公共 API。 在所有这些情况下,您可能希望通过以下方式之一 抑制该成员的使用检查:

  • 推荐的方法是为隐式使用的成员添加 代码注解属性。 为此目的有两个属性: [UsedImplicitly][PublicAPI] ,它们在功能上相似,但可以让您和您的团队成员了解该成员的实际使用方式。

  • 您还可以使用任何自定义属性抑制使用检查。 为此,请使用 [MeansImplicitUse]属性标记该属性的定义。

  • 最后,您可以像对待任何其他代码检查一样,通过 抑制注释或抑制属性来抑制特定的使用检查。

最后修改日期: 2025年 9月 27日