泛型参数基类型:“没有从 B 到 A 的隐式引用转换”
本文关键字:转换 引用 没有从 类型 基类 参数 泛型 | 更新日期: 2023-09-27 18:36:01
[Serializable]
public abstract class A
{
public A()
{
}
}
[Serializable]
public class B : A
{
public B() : base()
{
}
}
在扩展中:
public static T NextRecord<T>(this SqlDataReader reader) where T : A, new()
{
// Do work
}
我这样称呼这个扩展:
B b = reader.NextRecord<B>();
然而,我得到这个例外:"没有从'B'到'A'的隐式引用转换。
我做错了什么?
谢谢。
编辑
public static T NextRecord<T>(this SqlDataReader reader) where T : A, new()
{
// Make sure we have been given a correct Type
if (!typeof(T).BaseType.Equals(typeof(A)))
{
throw new Exception("Supplied Type is not derived from Type A");
}
if (reader.IsNull())
{
throw new ArgumentNullException("reader is null");
}
if (reader.HasRows)
{
if (reader.Read())
{
// Instance a object of the type, passing it the SqlDataReader so that it can populate itself
return Activator.CreateInstance(typeof(T), new object[] { reader }) as T;
}
}
return null;
}
这是扩展的代码
仍然有这个问题,尽管我通过将 T : A 更改为 T : 类的位置来解决这个问题。
我有第二个问题:
public class SomeOtherClass
{
public static void Test(SomeClassBase obj)
{
}
}
public abstract class SomeClassBase
{
public SomeClassBase()
{
SomeOtherClass.Test(this);
}
}
public class SomeClass : SomeClassBase
{
public SomeClass() : base()
{
}
}
我得到这个异常:
"'Namespace.SomeOtherClass.Test(Namespace.SomeClass)'的最佳重载方法匹配有一些无效的参数"
但是,从 ctor 中删除 mothod 调用并在外部调用它将起作用,如下所示:
SomeClass s = new SomeClass();SomeOtherClass.Test(s);
甚至将方法更改为:
public static void Test(SomeClass obj)
{
}
将失败:(
如果我将方法调用移动到派生类 ctor...