我能够重现您的问题
public interface IDetail<T>
{
}
public interface IMaster<T>
{
}
public class MyClass
{
public void method()
{
Principal aPrincipal = new Principal();
aPrincipal.Permissions.Foreach(x => aPrincipal.RemoveDetail(x)); // No suggestion from resharper
}
}
public class Permission : IDetail<Principal>
{
}
public class Principal : IMaster<Permission>
{
public virtual IEnumerable<Permission> Permissions { get; }
}
public static class Class
{
public static void RemoveDetail<TMaster, TChild>(this TMaster master, TChild child)
where TMaster : class, IMaster<TChild>
where TChild : class, IDetail<TMaster>
{
}
public static void Foreach<T>(this IEnumerable<T> source, Action<T> action)
{
}
}
resharper 没有提出任何建议。所以可能你必须将你的 Resharper 更新到更新的版本。可能是现在已修复的错误。
如果这不是你的方式。那么你必须提供更多信息。
当我尝试将其转换为方法组时,编译器也会给出相同的错误。所以这个问题可能仍然存在:为什么编译器不能这样做?
编辑:
要解决此问题,您必须RemoveDetail
从 Principal 内部调用该方法。所以让你的校长班像这样。
public class Principal : IMaster<Permission>
{
public virtual IEnumerable<Permission> Permissions { get; }
public void RemoveDetail(Permission p)
{
Class.RemoveDetail(this, p);
}
}
我认为编译器内部存在一种无法识别RemoveDetail
方法的模棱两可(可能是错误)。编译器如何尝试在其中找到它Principal
。RemoveDetail
因此您可以通过在内部创建并从那里Principal
调用静态来修复它。RemoveDetail
编辑2:
问题是泛型类型约束。
where TMaster : class, IMaster<TChild>
这使编译器可以查看实现的类IMaster<TChild>
和 thats Principal
。如果您删除此 where 子句,它将解决问题。否则编译器期望它应该是Principal
.
如果您使用 lambda,则可以消除这种歧义。
aPrincipal.RemoveDetail // compiler expects property/field/method in Principal
// but compiler forgets method group and static generic method!
x => aPrincipal.RemoveDetail(x) // this is no more like property or field
//but a method that is considered static generic method!
所以这是一个 C#6 错误